/* ============================================================
   Alicia Velásquez — original memorial design
   Cormorant Garamond + Mulish · ivory & sage
   ============================================================ */

:root{
  --bg:#f4efe6;
  --panel:#ece4d3;
  --ink:#33302a;
  --soft:#6f6658;
  --line:rgba(51,48,42,.14);
  --line-2:rgba(51,48,42,.22);
  --accent:#5e7359;
  --gold:#9a7b3f;
  --card:#fbf8f0;
  --shadow:0 18px 48px rgba(51,40,25,.15);
  --shadow-lg:0 26px 60px rgba(51,40,25,.18);
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0;
  background:var(--bg);
  color:var(--ink);
  font-family:'Mulish',system-ui,sans-serif;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
::selection{background:rgba(94,115,89,.22);}
img{display:block;max-width:100%;}

/* No text I-beam / blinking caret on non-editable content */
body{cursor:default;}
a{cursor:pointer;}
input,textarea{cursor:text;caret-color:auto;}
*:not(input):not(textarea){caret-color:transparent;}

/* ---- Language switcher ---- */
.lang-switcher{
  position:fixed; top:18px; right:18px; z-index:60;
  background:rgba(255,255,255,.9);
  border:1px solid var(--line-2);
  color:var(--soft);
  font-family:'Mulish',sans-serif;
  font-size:11px; letter-spacing:.18em; text-transform:uppercase; font-weight:600;
  padding:8px 16px; border-radius:999px; cursor:pointer;
  box-shadow:0 10px 24px -12px rgba(51,40,25,.3);
  transition:all .2s;
}
.lang-switcher:hover{background:var(--ink);color:var(--bg);border-color:var(--ink);}

/* ---- Generic ---- */
.eyebrow{
  font-family:'Mulish',sans-serif;
  font-size:12px; font-weight:600; letter-spacing:.28em; text-transform:uppercase;
  color:var(--accent);
}
.section{padding:clamp(40px,7vh,80px) clamp(24px,6vw,80px);}
h1,h2,h3{margin:0;}

/* ---- Hero ---- */
.hero{
  min-height:100vh;
  display:flex; flex-direction:column; align-items:center; justify-content:center; text-align:center;
  padding:clamp(56px,9vh,110px) clamp(24px,6vw,80px) clamp(48px,7vh,90px);
}
.hero .eyebrow{font-size:12px;letter-spacing:.34em;margin-bottom:clamp(26px,4vh,42px);}
.hero-frame{
  background:#fff; padding:11px; border-radius:2px;
  box-shadow:0 26px 60px rgba(51,40,25,.18);
  max-width:min(340px,72vw);
}
.hero-frame img{width:100%;height:auto;border-radius:1px;}
.hero h1{
  font-family:'Cormorant Garamond',serif; font-weight:500;
  font-size:clamp(52px,9.2vw,124px); line-height:.98; letter-spacing:-.015em;
  color:var(--ink); margin:clamp(30px,4.5vh,52px) 0 0; text-wrap:balance;
}
.hero h1 em{font-style:italic;font-weight:500;color:var(--accent);}
.hero-dates{
  display:flex; align-items:center; gap:18px; margin:26px 0 0;
  color:var(--soft); font-size:14px; letter-spacing:.22em; text-transform:uppercase; font-weight:500;
}
.hero-dates .rule{width:34px;height:1px;background:var(--line);}
.hero-epitaph{
  font-family:'Cormorant Garamond',serif; font-style:italic; font-weight:400;
  font-size:clamp(20px,2.5vw,29px); line-height:1.5; color:var(--soft);
  max-width:640px; margin:clamp(28px,4vh,40px) auto 0; text-wrap:balance;
}

/* ---- Dates band ---- */
.dates{max-width:1000px;margin:0 auto;padding:clamp(20px,4vh,40px) clamp(24px,6vw,80px) clamp(56px,9vh,110px);}
.dates-row{display:flex;flex-wrap:wrap;justify-content:center;border-top:1px solid var(--line);border-bottom:1px solid var(--line);}
.dates-cell{flex:1 1 240px;text-align:center;padding:clamp(30px,4vw,44px) 24px;border-right:1px solid var(--line);}
.dates-cell:last-child{border-right:none;}
.dates-label{font-size:11px;font-weight:600;letter-spacing:.3em;text-transform:uppercase;color:var(--accent);margin-bottom:14px;}
.dates-val{font-family:'Cormorant Garamond',serif;font-size:clamp(24px,2.6vw,30px);color:var(--ink);line-height:1.2;}
.dates-sub{font-size:13px;color:var(--soft);letter-spacing:.04em;margin-top:7px;}

/* ---- Chapter: text only ---- */
.chapter-text{max-width:780px;margin:0 auto;text-align:center;}
.chapter-text .eyebrow{display:block;margin-bottom:22px;}
.chapter-text h2{
  font-family:'Cormorant Garamond',serif;font-weight:500;font-size:clamp(34px,5vw,54px);
  line-height:1.05;letter-spacing:-.01em;color:var(--ink);margin:0 0 28px;text-wrap:balance;
}
.chapter-text p{font-size:clamp(16px,1.5vw,18px);line-height:1.85;color:var(--soft);margin:0 auto;max-width:620px;text-wrap:pretty;}
.chapter-text blockquote{
  font-family:'Cormorant Garamond',serif;font-style:italic;font-size:clamp(22px,3vw,32px);
  line-height:1.45;color:var(--ink);margin:clamp(36px,5vh,52px) auto 0;max-width:660px;text-wrap:balance;
}

/* ---- Chapter: split (image + text) ---- */
.split-inner{display:flex;flex-wrap:wrap;gap:clamp(34px,5vw,72px);align-items:center;max-width:1140px;margin:0 auto;}
.chapter-split.right .split-inner{flex-direction:row-reverse;}
@media (max-width:780px){.split-inner,.chapter-split.right .split-inner{flex-direction:column;}}
.split-media{flex:1 1 360px;}
.split-text{flex:1 1 360px;}
.split-text .eyebrow{display:block;margin-bottom:20px;}
.split-text h2{
  font-family:'Cormorant Garamond',serif;font-weight:500;font-size:clamp(32px,4.4vw,48px);
  line-height:1.06;letter-spacing:-.01em;color:var(--ink);margin:0 0 24px;text-wrap:balance;
}
.split-text p{font-size:clamp(16px,1.5vw,18px);line-height:1.85;color:var(--soft);margin:0;text-wrap:pretty;}
.photo-frame{background:#fff;padding:11px;border-radius:2px;box-shadow:var(--shadow);}
.photo-frame img{width:100%;height:auto;border-radius:1px;cursor:zoom-in;}
.photo-cap{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:15px;color:var(--soft);margin-top:13px;}

/* ---- Panel band ---- */
.panel-band{
  position:relative;
  isolation:isolate;
  overflow:hidden;
  background:var(--panel);
  padding:clamp(70px,11vh,126px) clamp(24px,6vw,80px) clamp(56px,9vh,104px);
  margin:clamp(20px,4vh,40px) 0;
}
.panel-band-inner{position:relative;z-index:1;max-width:780px;margin:0 auto;text-align:center;}
.panel-sewing{
  position:absolute;
  z-index:0;
  pointer-events:none;
  user-select:none;
  opacity:.72;
  filter:drop-shadow(0 18px 24px rgba(51,40,25,.12));
}
.panel-sewing--spool{
  bottom:clamp(-34px,-2.8vw,-12px);
  left:clamp(-72px,-1vw,8px);
  width:clamp(128px,16vw,224px);
  transform:rotate(-9deg);
}
.panel-sewing--needle{
  top:clamp(-50px,-3vw,-18px);
  right:clamp(-130px,-5vw,-36px);
  width:clamp(280px,38vw,520px);
  transform:rotate(6deg);
}
.panel-band .eyebrow{display:block;margin-bottom:22px;}
.panel-band h2{
  font-family:'Cormorant Garamond',serif;font-weight:500;font-size:clamp(32px,4.6vw,50px);
  line-height:1.06;letter-spacing:-.01em;color:var(--ink);margin:0 0 26px;text-wrap:balance;
}
.panel-band p{font-size:clamp(16px,1.55vw,18.5px);line-height:1.85;color:var(--soft);margin:0 auto;max-width:620px;text-wrap:pretty;}
@media (max-width:720px){
  .panel-band{padding-top:clamp(86px,22vw,120px);padding-bottom:clamp(86px,22vw,120px);}
  .panel-sewing{opacity:.5;}
  /* stack the sewing motifs top & bottom on mobile */
  .panel-sewing--needle{top:-14px;left:50%;right:auto;transform:translateX(-50%) rotate(4deg);width:clamp(220px,68vw,320px);}
  .panel-sewing--spool{top:auto;bottom:-12px;left:50%;right:auto;transform:translateX(-50%) rotate(-9deg);width:clamp(92px,24vw,128px);}
}

/* ---- Full-bleed band ---- */
.band{position:relative;margin:clamp(24px,4vh,48px) 0;}
.band{background:#1a1610;}
.band > img{width:100%;height:auto;max-height:88vh;object-fit:contain;display:block;margin:0 auto;cursor:zoom-in;}
.band-overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(20,17,12,.05) 0%,rgba(20,17,12,.12) 45%,rgba(20,17,12,.68) 100%);pointer-events:none;}
.band-quote{
  position:absolute;left:0;right:0;bottom:0;padding:clamp(28px,5vw,60px);text-align:center;
  font-family:'Cormorant Garamond',serif;font-style:italic;font-weight:400;
  font-size:clamp(24px,3.4vw,42px);color:#fff;margin:0;text-shadow:0 2px 18px rgba(0,0,0,.4);text-wrap:balance;
}

/* ---- Gallery ---- */
.gallery{padding:clamp(48px,8vh,96px) clamp(24px,6vw,80px) clamp(40px,6vh,72px);max-width:1240px;margin:0 auto;}
.gallery-head{text-align:center;margin-bottom:clamp(36px,5vh,56px);}
.gallery-head .eyebrow{display:block;margin-bottom:18px;}
.gallery-head h2{font-family:'Cormorant Garamond',serif;font-weight:500;font-size:clamp(32px,5vw,52px);line-height:1.05;color:var(--ink);margin:0;text-wrap:balance;}
.gallery-head h2 em{font-style:italic;color:var(--accent);font-weight:500;}
.gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:14px;}
.gallery-grid figure{margin:0;overflow:hidden;border-radius:2px;background:#fff;box-shadow:0 10px 30px rgba(51,40,25,.12);}
.gallery-grid img{width:100%;aspect-ratio:4/5;object-fit:cover;transition:transform .8s ease;cursor:zoom-in;}
.gallery-grid figure:hover img{transform:scale(1.045);}

/* ---- Slideshow ---- */
.slideshow{position:relative;background:#fff;border:1px solid rgba(0,0,0,.04);border-radius:2px;box-shadow:var(--shadow-lg);overflow:hidden;}
.slide-stage{position:relative;width:100%;height:clamp(420px,70vh,760px);background:#1a1610;overflow:hidden;touch-action:pan-y;}
.slide-stage .slide{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity 1.4s ease;background:#1a1610;pointer-events:none;}
.slide-stage .slide.active{opacity:1;pointer-events:auto;}
.slide-stage .slide img{max-width:100%;max-height:100%;width:auto;height:auto;object-fit:contain;box-shadow:0 30px 60px -20px rgba(0,0,0,.55);}
.slide-stage .slide video{max-width:100%;max-height:100%;width:auto;height:auto;object-fit:contain;box-shadow:0 30px 60px -20px rgba(0,0,0,.55);background:#000;}
.thumbs button video{width:100%;height:100%;object-fit:cover;filter:saturate(.92) brightness(.95);}
.thumbs button.is-video{position:relative;}
.thumbs button.is-video::after{content:'▶';position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:#fff;font-size:14px;text-shadow:0 1px 4px rgba(0,0,0,.7);pointer-events:none;}
.fs-slide video{width:100%;height:100%;object-fit:contain;}
.lightbox video{max-width:90vw;max-height:78vh;background:#000;border-radius:2px;box-shadow:0 30px 90px rgba(0,0,0,.55);}
.slide-stage .slide[data-kb="0"].active img{animation:kb-zoom-in 10s ease-in-out forwards;}
.slide-stage .slide[data-kb="1"].active img{animation:kb-zoom-out 10s ease-in-out forwards;}
.slide-stage .slide[data-kb="2"].active img{animation:kb-pan-r 10s ease-in-out forwards;}
.slide-stage .slide[data-kb="3"].active img{animation:kb-pan-l 10s ease-in-out forwards;}
@keyframes kb-zoom-in{0%{transform:scale(1) translate(0,0);}100%{transform:scale(1.12) translate(-2%,-1.5%);}}
@keyframes kb-zoom-out{0%{transform:scale(1.12) translate(2%,1.5%);}100%{transform:scale(1) translate(0,0);}}
@keyframes kb-pan-r{0%{transform:scale(1.08) translate(-3%,0);}100%{transform:scale(1.08) translate(3%,0);}}
@keyframes kb-pan-l{0%{transform:scale(1.08) translate(3%,0);}100%{transform:scale(1.08) translate(-3%,0);}}
.slide-nav{position:absolute;top:50%;transform:translateY(-50%);width:48px;height:48px;border-radius:50%;background:rgba(255,255,255,.86);color:var(--ink);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;z-index:4;box-shadow:0 6px 18px -6px rgba(0,0,0,.45);transition:background .2s,transform .2s;}
.slide-nav:hover{background:#fff;transform:translateY(-50%) scale(1.07);}
.slide-nav.prev{left:18px;}
.slide-nav.next{right:18px;}
.tap-overlay{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:72px;height:72px;background:rgba(0,0,0,.45);border-radius:50%;display:flex;align-items:center;justify-content:center;pointer-events:none;z-index:20;animation:tap-fade .9s ease forwards;}
@keyframes tap-fade{0%{opacity:.85;transform:translate(-50%,-50%) scale(.85);}30%{opacity:.85;transform:translate(-50%,-50%) scale(1);}100%{opacity:0;transform:translate(-50%,-50%) scale(1.15);}}
.slide-meta{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:18px 24px;border-top:1px solid var(--line);}
.slide-meta .count{font-family:'Mulish',sans-serif;font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:var(--soft);flex:0 0 auto;}
.slide-meta .caption{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:19px;color:var(--ink);text-align:center;flex:1;padding:0 18px;}
.slide-controls{display:flex;gap:10px;flex:0 0 auto;}
.slide-controls button{font-family:'Mulish',sans-serif;font-size:11px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;background:transparent;border:1px solid var(--line-2);color:var(--soft);padding:8px 14px;cursor:pointer;border-radius:999px;transition:all .2s;white-space:nowrap;}
.slide-controls button:hover{color:var(--ink);border-color:var(--soft);}
.slide-controls button.is-playing{background:var(--accent);color:#fff;border-color:var(--accent);}
.slide-dots{display:flex;flex-wrap:wrap;gap:6px;justify-content:center;padding:0 24px 22px;}
.slide-dots button{width:8px;height:8px;border-radius:50%;border:none;background:var(--line-2);cursor:pointer;padding:0;transition:all .2s;}
.slide-dots button:hover{background:var(--soft);}
.slide-dots button.active{background:var(--accent);width:22px;border-radius:999px;}
.thumbs{display:grid;grid-template-columns:repeat(auto-fill,minmax(82px,1fr));gap:8px;margin-top:18px;}
.thumbs button{border:none;padding:0;background:transparent;cursor:pointer;aspect-ratio:1;overflow:hidden;border-radius:2px;outline:2px solid transparent;outline-offset:2px;transition:outline-color .2s;}
.thumbs button img{width:100%;height:100%;object-fit:cover;transition:transform .4s ease,filter .3s;filter:saturate(.92) brightness(.95);}
.thumbs button:hover img{transform:scale(1.08);filter:none;}
.thumbs button.active{outline-color:var(--accent);}
.thumbs button.active img{filter:none;}
@media (max-width:640px){
  .slide-nav{width:40px;height:40px;}
  .slide-meta{flex-wrap:wrap;padding-right:26px;}
  .slide-meta .caption{flex:0 0 100%;order:-1;text-align:left;padding:0;font-size:17px;}
  .slide-controls{padding-right:6px;}
}

/* ---- Fullscreen slideshow ---- */
.fs-slideshow{position:fixed;inset:0;background:#0e0b07;z-index:9998;display:flex;flex-direction:column;overflow:hidden;animation:fadeIn .3s ease;}
@keyframes fadeIn{from{opacity:0;}to{opacity:1;}}
.fs-stage{flex:1;position:relative;overflow:hidden;}
.fs-slide{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity 1.1s ease;}
.fs-slide.active{opacity:1;}
.fs-slide img{width:100%;height:100%;object-fit:contain;}
.fs-slide[data-kb="0"].active img{animation:kb-zoom-in 10s ease-in-out forwards;}
.fs-slide[data-kb="1"].active img{animation:kb-zoom-out 10s ease-in-out forwards;}
.fs-slide[data-kb="2"].active img{animation:kb-pan-r 10s ease-in-out forwards;}
.fs-slide[data-kb="3"].active img{animation:kb-pan-l 10s ease-in-out forwards;}
.fs-close{position:absolute;top:20px;right:24px;background:transparent;border:1px solid rgba(255,255,255,.3);color:rgba(255,255,255,.8);width:44px;height:44px;border-radius:50%;cursor:pointer;z-index:10;display:flex;align-items:center;justify-content:center;opacity:0;transition:background .2s,opacity .3s;}
.fs-slideshow:hover .fs-close{opacity:1;}
.fs-close:hover{background:rgba(255,255,255,.12);}
.fs-nav{position:absolute;top:50%;transform:translateY(-50%);background:transparent;border:1px solid rgba(255,255,255,.3);color:rgba(255,255,255,.8);width:56px;height:56px;border-radius:50%;cursor:pointer;z-index:10;display:flex;align-items:center;justify-content:center;opacity:0;transition:background .2s,opacity .3s;}
.fs-slideshow:hover .fs-nav{opacity:1;}
.fs-nav:hover{background:rgba(255,255,255,.12);}
.fs-nav.prev{left:28px;}
.fs-nav.next{right:28px;}
.fs-bottom{display:flex;align-items:center;justify-content:space-between;gap:24px;padding:18px 40px;}
.fs-caption{display:flex;flex-direction:column;gap:3px;}
.fs-cap-es{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:20px;color:rgba(255,255,255,.88);}
.fs-cap-en{font-family:'Mulish',sans-serif;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,.4);}
.fs-controls{display:flex;align-items:center;gap:18px;opacity:0;transition:opacity .3s;}
.fs-slideshow:hover .fs-controls{opacity:1;}
.fs-count{font-family:'Mulish',sans-serif;font-size:11px;letter-spacing:.22em;color:rgba(255,255,255,.4);}
.fs-play,.fs-mute{background:transparent;border:1px solid rgba(255,255,255,.3);color:rgba(255,255,255,.7);width:36px;height:36px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;transition:background .2s;}
.fs-play:hover,.fs-mute:hover{background:rgba(255,255,255,.1);}
.fs-play.is-playing{background:rgba(255,255,255,.12);color:#fff;}
.fs-progress{height:3px;background:rgba(255,255,255,.1);}
.fs-bar{height:100%;width:0;background:var(--gold);animation:fs-progress linear;}
@keyframes fs-progress{from{width:0;}to{width:100%;}}
@media (max-width:768px){
  .fs-nav,.fs-close,.fs-controls{opacity:1;}
  .fs-bottom{padding:12px 16px;}
  .fs-count{display:none;}
  .fs-cap-es{font-size:16px;}
}

/* ---- Tributes (static, "In their words") ---- */
.tributes{background:var(--panel);padding:clamp(56px,9vh,104px) clamp(24px,6vw,80px);}
.tributes-inner{max-width:1080px;margin:0 auto;}
.tributes-head{text-align:center;margin-bottom:clamp(40px,5.5vh,60px);}
.tributes-head .eyebrow{display:block;margin-bottom:18px;}
.tributes-head h2{font-family:'Cormorant Garamond',serif;font-weight:500;font-size:clamp(32px,5vw,52px);line-height:1.05;color:var(--ink);margin:0;text-wrap:balance;}
.tributes-grid{display:flex;flex-wrap:wrap;gap:clamp(20px,3vw,32px);}
.tribute-card{flex:1 1 360px;margin:0;background:var(--bg);border:1px solid var(--line);border-radius:3px;padding:clamp(30px,4vw,44px);}
.tribute-mark{font-family:'Cormorant Garamond',serif;color:var(--accent);font-size:48px;line-height:.6;height:26px;}
.tribute-quote{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:clamp(19px,2.2vw,25px);line-height:1.5;color:var(--ink);margin:0 0 24px;text-wrap:pretty;}
.tribute-by{font-family:'Mulish',sans-serif;font-size:12px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--soft);}
.tribute-rel{font-weight:400;}

/* ---- Board (memories + photos) ---- */
.board{background:var(--bg);padding:clamp(56px,9vh,104px) clamp(24px,6vw,80px);border-top:1px solid var(--line);}
.board-inner{max-width:1080px;margin:0 auto;}
.board-head{text-align:center;margin-bottom:clamp(28px,4vh,40px);}
.board-head .eyebrow{display:block;margin-bottom:18px;}
.board-head h2{font-family:'Cormorant Garamond',serif;font-weight:500;font-size:clamp(32px,5vw,52px);line-height:1.05;color:var(--ink);margin:0;text-wrap:balance;}
.board-head h2 em{font-style:italic;color:var(--accent);font-weight:500;}
.board-intro{text-align:center;max-width:56ch;margin:0 auto clamp(32px,5vh,48px);color:var(--soft);font-size:clamp(15px,1.4vw,17px);line-height:1.7;}
.board-intro p{margin:0;}

.board-form{
  background:var(--card);border:1px solid var(--line);border-radius:3px;
  padding:clamp(24px,4vw,40px);max-width:660px;margin:0 auto clamp(44px,7vh,72px);box-shadow:var(--shadow);
}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px;}
@media (max-width:600px){.form-row{grid-template-columns:1fr;}}
.board-form label{display:block;font-family:'Mulish',sans-serif;font-size:10px;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--soft);margin-bottom:6px;}
.board-form input,.board-form textarea{
  width:100%;background:var(--bg);border:1px solid var(--line-2);padding:12px 14px;
  font-family:'Mulish',sans-serif;font-size:16px;color:var(--ink);border-radius:2px;outline:none;resize:vertical;transition:border-color .2s;
}
.board-form input:focus,.board-form textarea:focus{border-color:var(--accent);}
.board-form textarea{min-height:120px;line-height:1.6;}
.field{margin-bottom:16px;}

.photo-field{margin-bottom:4px;}
/* scoped + reset so the generic ".board-form label" rule doesn't flatten it */
.board-form .photo-drop{
  display:flex;align-items:center;gap:12px;width:100%;padding:15px 18px;margin:0;
  background:var(--bg);border:1px dashed var(--line-2);border-radius:2px;color:var(--soft);
  font-family:'Mulish',sans-serif;font-size:13px;font-weight:500;letter-spacing:normal;text-transform:none;
  cursor:pointer;transition:border-color .2s,color .2s;
}
.board-form .photo-drop:hover{border-color:var(--accent);color:var(--ink);}
.board-form .photo-drop svg{flex:0 0 auto;color:var(--accent);}
.board-form .photo-drop span{display:inline-block;}
.photo-input{display:none;}
.photo-preview{position:relative;margin-top:14px;display:inline-block;max-width:100%;background:#fff;padding:10px;box-shadow:var(--shadow);}
.photo-preview img{max-width:240px;max-height:240px;width:auto;height:auto;border-radius:1px;}
.photo-remove{position:absolute;top:-10px;right:-10px;width:26px;height:26px;border-radius:50%;border:none;background:var(--ink);color:var(--bg);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:14px;line-height:1;box-shadow:var(--shadow);}

.board-actions{display:flex;justify-content:center;margin-top:18px;}
.board-submit{
  background:var(--accent);color:#fbf8f0;border:none;padding:13px 30px;
  font-family:'Mulish',sans-serif;font-size:12px;font-weight:600;letter-spacing:.22em;text-transform:uppercase;
  cursor:pointer;border-radius:999px;transition:background .2s;
}
.board-submit:hover{background:var(--ink);}
.board-submit:disabled{opacity:.55;cursor:default;}
.board-note{text-align:center;font-family:'Mulish',sans-serif;font-size:11px;color:var(--soft);margin-top:14px;}
.board-error{text-align:center;font-family:'Mulish',sans-serif;font-size:12px;color:#a85c54;margin-top:12px;}

/* cards (masonry) */
.board-cards{column-count:2;column-gap:24px;}
@media (max-width:720px){.board-cards{column-count:1;}}
.gb-card{
  break-inside:avoid;display:inline-block;width:100%;margin-bottom:24px;
  padding:26px 28px 24px;background:var(--card);border:1px solid var(--line);border-radius:3px;position:relative;box-sizing:border-box;box-shadow:var(--shadow);
}
.gb-card .quote-mark{font-family:'Cormorant Garamond',serif;color:var(--accent);font-size:48px;line-height:.6;height:24px;}
.gb-card .body{color:var(--ink);font-family:'Cormorant Garamond',serif;font-style:italic;font-size:clamp(18px,1.8vw,22px);line-height:1.5;}
.gb-card .body-translated{color:var(--soft);font-size:14.5px;line-height:1.6;margin-top:12px;padding-top:12px;border-top:1px solid var(--line);}
.gb-card .meta{display:flex;align-items:baseline;justify-content:space-between;margin-top:18px;gap:16px;}
.gb-card .who{font-family:'Mulish',sans-serif;font-size:12px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--ink);}
.gb-card .rel{font-family:'Mulish',sans-serif;font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--soft);margin-top:4px;}
.gb-card .when{font-family:'Mulish',sans-serif;font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--soft);flex:0 0 auto;}
.gb-card .card-photo{margin:-26px -28px 18px;background:#1a1610;overflow:hidden;border-bottom:1px solid var(--line);}
.gb-card .card-photo img{width:100%;height:auto;max-height:420px;object-fit:cover;cursor:zoom-in;transition:transform .5s ease;}
.gb-card .card-photo:hover img{transform:scale(1.03);}
.gb-card.photo-only .card-photo{margin-bottom:0;}
@media (max-width:480px){.gb-card .card-photo{margin:-26px -28px 18px;}}

/* owner edit / delete */
.card-actions{position:absolute;top:10px;right:10px;display:flex;gap:4px;opacity:0;transition:opacity .2s;}
.gb-card--owned:hover .card-actions{opacity:1;}
.card-action-btn{display:flex;align-items:center;justify-content:center;padding:5px 8px;background:var(--card);border:1px solid var(--line-2);border-radius:4px;cursor:pointer;color:var(--soft);font-family:'Mulish',sans-serif;font-size:11px;transition:color .15s,border-color .15s;}
.card-action-btn:hover{color:var(--ink);border-color:var(--soft);}
.card-action-delete:hover{color:#a83228;border-color:#a83228;}
.card-action-confirm{color:#a83228;border-color:#a83228;}
.card-edit-form{display:flex;flex-direction:column;gap:10px;}
.card-edit-input,.card-edit-textarea{width:100%;padding:9px 11px;border:1px solid var(--line-2);border-radius:4px;font-family:'Mulish',sans-serif;font-size:14px;color:var(--ink);background:var(--card);box-sizing:border-box;}
.card-edit-textarea{min-height:90px;resize:vertical;}
.card-edit-actions{display:flex;gap:8px;justify-content:flex-end;}
.card-edit-save{padding:7px 16px;background:var(--accent);color:#fff;border:none;border-radius:4px;font-family:'Mulish',sans-serif;font-size:13px;cursor:pointer;}
.card-edit-save:disabled{opacity:.5;cursor:default;}
.card-edit-cancel{padding:7px 16px;background:transparent;color:var(--soft);border:1px solid var(--line-2);border-radius:4px;font-family:'Mulish',sans-serif;font-size:13px;cursor:pointer;}

/* ---- Closing ---- */
.closing{padding:clamp(72px,13vh,150px) clamp(24px,6vw,80px);text-align:center;}
.diamond{display:flex;align-items:center;justify-content:center;gap:14px;margin-bottom:clamp(30px,5vh,44px);}
.diamond .line{width:30px;height:1px;background:var(--line);}
.diamond .dot{width:7px;height:7px;border:1px solid var(--accent);transform:rotate(45deg);}
.closing .eyebrow{display:block;font-size:12px;letter-spacing:.3em;margin-bottom:30px;}
.closing-quote{font-family:'Cormorant Garamond',serif;font-weight:500;font-size:clamp(34px,6vw,68px);line-height:1.12;color:var(--ink);margin:0 auto;max-width:840px;text-wrap:balance;}
.closing-cite{font-size:13px;letter-spacing:.2em;text-transform:uppercase;color:var(--soft);margin-top:26px;}
.closing-line{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:clamp(19px,2.3vw,27px);line-height:1.55;color:var(--soft);max-width:600px;margin:clamp(36px,5vh,52px) auto 0;text-wrap:balance;}

/* ---- Footer ---- */
.foot{border-top:1px solid var(--line);padding:clamp(36px,6vh,64px) 24px;text-align:center;}
.foot-name{font-family:'Cormorant Garamond',serif;font-size:clamp(22px,3vw,30px);color:var(--ink);}
.foot-dates{font-size:12px;letter-spacing:.24em;text-transform:uppercase;color:var(--soft);margin-top:12px;}
.foot-credit{margin-top:28px;font-family:'Mulish',sans-serif;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--soft);line-height:1.9;}
.foot-credit a{display:inline-block;margin-top:12px;color:var(--accent);text-decoration:none;border-bottom:1px solid var(--line-2);padding-bottom:2px;}
.foot-credit a:hover{color:var(--ink);}

/* ---- Lightbox ---- */
.lightbox{position:fixed;inset:0;z-index:9999;display:flex;align-items:center;justify-content:center;flex-direction:column;background:rgba(24,21,16,.94);padding:6vh 4vw;animation:lb-fade .42s ease;}
@keyframes lb-fade{from{opacity:0;}to{opacity:1;}}
.lightbox img{max-width:90vw;max-height:78vh;object-fit:contain;border-radius:2px;box-shadow:0 30px 90px rgba(0,0,0,.55);background:#fff;padding:8px;}
.lightbox-cap{margin-top:20px;color:rgba(255,255,255,.85);font-family:'Cormorant Garamond',serif;font-style:italic;font-size:19px;text-align:center;}
.lightbox-btn{position:absolute;background:rgba(255,255,255,.08);color:#fff;border:1px solid rgba(255,255,255,.28);width:54px;height:54px;border-radius:50%;font-size:24px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .25s;}
.lightbox-btn:hover{background:rgba(255,255,255,.2);}
.lightbox-prev{left:max(3vw,16px);top:50%;transform:translateY(-50%);}
.lightbox-next{right:max(3vw,16px);top:50%;transform:translateY(-50%);}
.lightbox-close{top:22px;right:26px;width:auto;height:auto;border:none;background:none;color:rgba(255,255,255,.72);font-size:24px;}
.lightbox-close:hover{background:none;color:#fff;}
