
:root{
  --paper:#faf6f0; --paper-2:#f3ece2; --card:#ffffff;
  --ink:#2c2620; --ink-2:#6f665b; --faint:#a99e90;
  --gold:#b08442; --gold-deep:#8f6628; --blush:#ecdcd3; --line:#e6dacd;
  --shadow:0 1px 2px rgba(44,38,32,.05), 0 10px 30px rgba(44,38,32,.07);
  --radius:16px; --maxw:1120px;
  --display:'Fraunces',Georgia,'Times New Roman',serif;
  --sans:system-ui,-apple-system,'Segoe UI',Roboto,sans-serif;
}
*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{margin:0;background:var(--paper);color:var(--ink);font-family:var(--sans);
  font-size:16px;line-height:1.55;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
img{max-width:100%;display:block}
a{color:var(--gold-deep);text-decoration:none}
a:hover{text-decoration:underline}
:focus-visible{outline:2px solid var(--gold);outline-offset:2px;border-radius:4px}

/* ---- brand ---- */
.wordmark{font-family:var(--display);font-weight:600;font-size:1.05rem;letter-spacing:.01em;color:var(--ink);
  display:inline-flex;align-items:center;gap:.5em}
.wordmark .seal{width:.6em;height:.6em;border-radius:50%;background:var(--gold);
  box-shadow:0 0 0 .18em var(--blush)}
.eyebrow{font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-2);font-weight:600}

/* ---- type ---- */
h1,h2,h3{font-family:var(--display);font-weight:500;line-height:1.06;margin:.25em 0}
.display{font-family:var(--display)}
.lede{color:var(--ink-2);font-size:1.05rem}
.muted{color:var(--ink-2)}

/* ---- buttons ---- */
.btn{font:inherit;font-weight:600;border-radius:999px;padding:.72rem 1.35rem;cursor:pointer;
  border:1px solid transparent;display:inline-flex;align-items:center;gap:.5em;
  transition:transform .08s ease, background .15s ease, border-color .15s ease;text-decoration:none}
.btn:active{transform:translateY(1px)}
.btn-gold{background:var(--gold);color:#fff;border-color:var(--gold)}
.btn-gold:hover{background:var(--gold-deep);text-decoration:none;color:#fff}
.btn-ghost{background:transparent;color:var(--ink);border-color:var(--line)}
.btn-ghost:hover{background:var(--paper-2);text-decoration:none}

/* ---- form ---- */
.field{font:inherit;width:100%;padding:.85rem 1rem;border-radius:12px;border:1px solid var(--line);
  background:var(--card);color:var(--ink)}
.field::placeholder{color:var(--faint)}
.field:focus{outline:2px solid var(--gold);outline-offset:1px;border-color:var(--gold)}

/* ---- layout ---- */
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 1.2rem}
.col{max-width:33rem;margin:0 auto;padding:clamp(2rem,7vw,3.6rem) 1.2rem}
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow)}
.stack > * + *{margin-top:.8rem}
.center{text-align:center}

/* ---- copyable link row ---- */
.linkrow{display:flex;gap:.5rem;align-items:stretch;margin:.5rem 0}
.linkrow input{font:inherit;flex:1;min-width:0;padding:.7rem .85rem;border:1px solid var(--line);
  border-radius:10px;background:var(--paper-2);color:var(--ink-2);overflow:hidden;text-overflow:ellipsis}
.copy{white-space:nowrap}
.copy.done{background:var(--blush);border-color:var(--gold);color:var(--gold-deep)}

/* ---- theme picker ---- */
.themes{display:grid;grid-template-columns:repeat(4,1fr);gap:.5rem}
.theme-swatch{background:none;border:1px solid var(--line);border-radius:12px;padding:.45rem;cursor:pointer;
  display:flex;flex-direction:column;align-items:center;gap:.35rem;transition:border-color .15s ease,box-shadow .15s ease}
.theme-swatch.sel{border-color:var(--gold);box-shadow:0 0 0 2px var(--blush)}
.theme-swatch .sw{width:100%;height:32px;border-radius:8px;border:1px solid rgba(0,0,0,.07);
  display:flex;align-items:center;justify-content:center;gap:4px}
.theme-swatch .sw i{width:9px;height:9px;border-radius:50%;display:block}
.theme-swatch .tn{font-size:.74rem;color:var(--ink-2);font-weight:600}
@media(max-width:430px){.themes{grid-template-columns:repeat(2,1fr)}}

/* ---- uploader (drop zone + progress rows) ---- */
.dropzone{display:flex;align-items:center;justify-content:center;text-align:center;
  border:2px dashed var(--line);border-radius:16px;padding:2.3rem 1rem;cursor:pointer;background:var(--card);
  transition:border-color .15s ease, background .15s ease}
.dropzone.over{border-color:var(--gold);background:var(--paper-2)}
.dz-inner b{display:block;font-family:var(--display);font-size:1.25rem}
.dz-inner span{color:var(--ink-2);font-size:.9rem}
.uplist{margin-top:1rem}
.uprow{display:flex;gap:.8rem;align-items:center;padding:.55rem;border-radius:12px;background:var(--card);
  border:1px solid var(--line);margin-bottom:.5rem}
.upthumb{width:52px;height:52px;border-radius:10px;background:var(--paper-2) center/cover no-repeat;flex:none}
.upmeta{flex:1;min-width:0}
.upname{font-size:.85rem;color:var(--ink-2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:.35rem}
.bar{height:6px;background:var(--paper-2);border-radius:99px;overflow:hidden}
.bar i{display:block;height:100%;width:0;background:var(--gold);transition:width .2s ease}
.uprow.done .upname::after{content:" ✓";color:var(--gold-deep);font-weight:700}
.uprow.err .bar i{background:#c0564e;width:100%!important}

/* ---- gallery ---- */
.gallery-head{text-align:center;padding:clamp(2rem,6vw,3.2rem) 1.2rem 1.2rem}
.event-name{font-size:clamp(2.1rem,6.5vw,3.6rem);margin:.3rem 0 .1rem}
.count{color:var(--ink-2);font-size:.98rem;margin:.1rem 0 1.2rem}
.count b{color:var(--gold-deep);font-weight:600;font-variant-numeric:tabular-nums}
.head-actions{display:flex;gap:.6rem;justify-content:center;flex-wrap:wrap}
.toolbar{display:flex;gap:.6rem;justify-content:center;align-items:center;flex-wrap:wrap;margin-top:.85rem}
.pills{display:inline-flex;background:var(--paper-2);border-radius:999px;padding:3px}
.pill{font:inherit;font-size:.82rem;font-weight:600;border:none;background:none;color:var(--ink-2);
  padding:.38rem .85rem;border-radius:999px;cursor:pointer}
.pill.on{background:var(--card);color:var(--ink);box-shadow:var(--shadow)}
.pill.solo{border:1px solid var(--line);background:var(--card)}

.grid{column-count:4;column-gap:12px;max-width:var(--maxw);margin:0 auto;padding:0 12px 4rem}
.grid figure{break-inside:avoid;margin:0 0 12px;position:relative;cursor:zoom-in;border-radius:14px;
  overflow:hidden;background:var(--paper-2);box-shadow:var(--shadow);animation:rise .5s ease both}
.grid img{width:100%;transition:transform .4s ease;background:var(--paper-2)}
.grid figure:hover img{transform:scale(1.04)}
.grid figure.video::after{content:"";position:absolute;left:50%;top:50%;width:54px;height:54px;
  transform:translate(-50%,-50%);border-radius:50%;background:rgba(255,255,255,.85);
  box-shadow:var(--shadow)}
.grid figure.video::before{content:"";position:absolute;left:calc(50% + 3px);top:50%;
  transform:translate(-50%,-50%);border-style:solid;border-width:9px 0 9px 15px;
  border-color:transparent transparent transparent var(--gold-deep);z-index:1}
@media(max-width:980px){.grid{column-count:3}}
@media(max-width:640px){.grid{column-count:2;column-gap:8px}.grid figure{margin-bottom:8px}}
@keyframes rise{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}

.empty{max-width:30rem;margin:2rem auto 5rem;text-align:center;color:var(--ink-2);padding:0 1.2rem}
.empty .big{font-family:var(--display);font-size:1.6rem;color:var(--ink);margin-bottom:.3rem}

/* ---- lightbox ---- */
.lightbox{position:fixed;inset:0;z-index:60;display:none;align-items:center;justify-content:center;
  background:rgba(28,23,18,.93)}
.lightbox.open{display:flex;animation:fade .2s ease}
.lightbox img,.lightbox video{max-width:92vw;max-height:80vh;border-radius:8px;
  box-shadow:0 24px 70px rgba(0,0,0,.55);animation:imgfade .35s ease}
@keyframes imgfade{from{opacity:0}to{opacity:1}}
.lightbox.show .lb-btn{opacity:0;pointer-events:none}  /* slideshow hides chrome */
.lb-btn{position:absolute;background:rgba(255,255,255,.13);color:#fff;border:none;cursor:pointer;
  width:3.1rem;height:3.1rem;border-radius:50%;font-size:1.7rem;display:grid;place-items:center;
  transition:background .15s ease}
.lb-btn:hover{background:rgba(255,255,255,.26)}
.lb-close{top:1rem;right:1rem}.lb-prev{left:1rem;top:50%;transform:translateY(-50%)}
.lb-next{right:1rem;top:50%;transform:translateY(-50%)}
.lb-bar{position:absolute;bottom:0;left:0;right:0;padding:1.1rem;display:flex;gap:1rem;
  align-items:center;justify-content:center;color:#fff;
  background:linear-gradient(transparent,rgba(0,0,0,.5))}
.lb-bar .who{font-size:.9rem;opacity:.85}
@keyframes fade{from{opacity:0}to{opacity:1}}

/* ---- footer ---- */
.foot{text-align:center;padding:2.4rem 1.2rem 3rem;color:var(--faint);font-size:.85rem;
  border-top:1px solid var(--line);margin-top:1rem}
.foot .wordmark{font-size:.95rem}

/* ---- landing ---- */
.nav{display:flex;align-items:center;justify-content:space-between;max-width:60rem;margin:0 auto;
  padding:1.2rem 1.2rem 0}
.hero{text-align:center;padding:clamp(2.6rem,8vw,5rem) 1.2rem 2rem;max-width:46rem;margin:0 auto}
.hero h1{font-size:clamp(2.4rem,8vw,4.3rem);line-height:1.02;margin:.5rem 0}
.hero .lede{font-size:clamp(1.05rem,2.6vw,1.22rem);max-width:33rem;margin:1.1rem auto 1.7rem}
.cta-row{display:flex;gap:.7rem;justify-content:center;flex-wrap:wrap}
.section{max-width:58rem;margin:0 auto;padding:2.6rem 1.2rem}
.section > h2{font-size:clamp(1.7rem,5vw,2.4rem);text-align:center}
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem;margin-top:1.6rem}
.step .n{font-family:var(--display);font-size:2.1rem;color:var(--gold);line-height:1}
.step h3{font-size:1.15rem;margin:.45rem 0 .25rem}
.step p{color:var(--ink-2);font-size:.95rem;margin:0}
@media(max-width:680px){.steps{grid-template-columns:1fr;gap:1.1rem;text-align:center}}
.theme-strip{display:grid;grid-template-columns:repeat(4,1fr);gap:.8rem;margin-top:1.5rem}
.theme-card{background:var(--paper);color:var(--ink);border:1px solid var(--line);border-radius:16px;
  padding:1.5rem .8rem;text-align:center}
.theme-card .dot{width:1.6rem;height:1.6rem;border-radius:50%;background:var(--gold);margin:0 auto .5rem;
  box-shadow:0 0 0 .3rem var(--blush)}
.theme-card .tn{font-family:var(--display);font-size:1.08rem}
@media(max-width:560px){.theme-strip{grid-template-columns:repeat(2,1fr)}}
.bigcta{text-align:center;padding:clamp(2.6rem,8vw,4.5rem) 1.2rem;position:relative}
.bigcta h2{font-size:clamp(1.9rem,6vw,3rem);max-width:24rem;margin:0 auto .3rem}
.hero{position:relative;overflow:visible}
.hero::before{content:"";position:absolute;left:50%;top:34%;transform:translate(-50%,-50%);
  width:min(42rem,92vw);height:26rem;border-radius:50%;
  background:radial-gradient(closest-side,var(--blush),transparent 72%);opacity:.7;z-index:-1;pointer-events:none}
.filmstrip{display:flex;gap:10px;overflow:hidden;max-width:62rem;margin:2rem auto 0;padding:0 1rem;
  -webkit-mask:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent);
  mask:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent)}
.filmstrip img{height:148px;width:auto;border-radius:12px;flex:none;object-fit:cover;box-shadow:var(--shadow)}
.filmcap{text-align:center;color:var(--faint);font-size:.82rem;margin-top:.7rem}
.rule{width:44px;height:2px;background:var(--gold);border:none;margin:1.6rem auto}
.reveal{animation:rise .7s ease both}
.boxcard{max-width:48rem;margin:0 auto;text-align:center;padding:clamp(2rem,5vw,3.2rem);
  background:var(--card);color:var(--ink);border:1px solid var(--line);border-radius:20px;box-shadow:var(--shadow)}
.boxcard .lede{margin:1rem auto 1.5rem}
.box-ico{width:84px;height:84px;color:var(--gold-deep);display:block;margin:.2rem auto 1rem}
.boxgrid{display:grid;grid-template-columns:1fr 1fr;gap:.7rem;max-width:30rem;margin:1.3rem auto 0;
  text-align:left;font-size:.9rem;color:var(--ink-2)}
.boxgrid b{color:var(--gold-deep)}
@media(max-width:520px){.boxgrid{grid-template-columns:1fr}}

/* ---- themes (palette swaps; Heirloom is the :root default) ---- */
[data-theme="midnight"]{
  --paper:#17140f; --paper-2:#211c15; --card:#211c15;
  --ink:#f1ebdf; --ink-2:#b6ab98; --faint:#7e7461;
  --gold:#caa055; --gold-deep:#e3c082; --blush:#3a3024; --line:#352c20;
  --shadow:0 1px 2px rgba(0,0,0,.4), 0 12px 34px rgba(0,0,0,.4);
}
[data-theme="garden"]{
  --paper:#f3f5ed; --paper-2:#e7ede0; --card:#fbfcf8;
  --ink:#2c332a; --ink-2:#5f6a58; --faint:#9aa291;
  --gold:#6f8a5e; --gold-deep:#546f45; --blush:#dde6d3; --line:#dde4d3;
}
[data-theme="blush"]{
  --paper:#fbf3f1; --paper-2:#f5e7e3; --card:#fffafa;
  --ink:#43302e; --ink-2:#8a6d69; --faint:#c0a39e;
  --gold:#c2766f; --gold-deep:#a85850; --blush:#f3ddd8; --line:#f1e1dc;
}

@media (prefers-reduced-motion:reduce){*{transition:none!important;animation:none!important}}
