:root{
  --bg:#0c0b09;
  --bg-deep:#050505;
  --ink:#f1ebdf;
  --ink-soft:rgba(241,235,223,.62);
  --ink-faint:rgba(241,235,223,.40);
  --line:rgba(241,235,223,.15);
  --brass:#c8a96a;
  --serif:"Newsreader", Georgia, serif;
  --mono:"IBM Plex Mono", ui-monospace, monospace;
}
*{box-sizing:border-box;}
html,body{margin:0;padding:0;background:var(--bg-deep);color:var(--ink);-webkit-font-smoothing:antialiased;}
body{font-family:var(--mono);line-height:1.6;}

.sheet{
  max-width:720px;margin:0 auto;background:var(--bg);
  background-image:radial-gradient(120% 60% at 50% -5%, rgba(200,169,106,.07), transparent 60%);
  border-left:1px solid var(--line);border-right:1px solid var(--line);
  min-height:100vh;
}
.pad{padding:0 56px;}
@media (max-width:560px){ .pad{padding:0 28px;} }

/* ---- masthead ---- */
.masthead{padding-top:64px;text-align:center;}
.kicker{font-family:var(--mono);font-size:11px;letter-spacing:.46em;color:var(--ink-soft);margin-bottom:34px;}
.pre{font-family:var(--serif);font-style:italic;font-weight:300;font-size:30px;color:var(--ink);letter-spacing:.01em;margin-bottom:2px;}
.big50{font-family:var(--serif);font-weight:200;font-style:italic;font-size:200px;line-height:.82;letter-spacing:-.04em;color:var(--brass);text-shadow:0 2px 40px rgba(200,169,106,.18);}
.strap{font-family:var(--mono);font-size:11px;letter-spacing:.40em;color:var(--ink-soft);margin-top:18px;}
@media (max-width:560px){ .big50{font-size:128px;} .pre{font-size:24px;} }

/* ---- date bar ---- */
.datebar{display:flex;flex-direction:column;align-items:center;gap:10px;
  margin:48px 0 0;padding:20px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  font-family:var(--mono);font-size:12px;letter-spacing:.22em;color:var(--ink);text-align:center;}
.datebar .when{color:var(--ink);}
.datebar .where{color:var(--ink-soft);letter-spacing:.26em;}

/* ---- note ---- */
.note{font-family:var(--serif);font-size:21px;line-height:1.62;color:#ece5d6;margin:52px 0 0;text-wrap:pretty;}
.note p{margin:0 0 16px;}
.note p:last-of-type{margin-bottom:0;}
.note .to{font-family:var(--serif);font-size:21px;color:var(--ink);margin-bottom:22px;}
.note .to strong{font-weight:500;}
.note .sig{font-family:"Caveat",cursive;font-size:42px;line-height:1;color:var(--ink);margin-top:30px;}

/* ---- staircase plate ---- */
.plate{position:relative;margin:44px 0 0;background:#08070a;
  box-shadow:0 0 0 1px var(--brass), 0 24px 60px rgba(0,0,0,.5);overflow:hidden;
  aspect-ratio:16/9;}
.plate-media{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center 42%;display:block;}
.plate-shadow{position:absolute;inset:0;pointer-events:none;box-shadow:inset 0 0 70px rgba(0,0,0,.55);}
.plate-cap{position:absolute;left:18px;bottom:14px;margin:0;font-family:var(--mono);
  font-size:11px;letter-spacing:.24em;color:rgba(241,235,223,.82);text-shadow:0 1px 12px rgba(0,0,0,.85);}
@media (max-width:560px){ .plate{margin-top:32px;} .plate-cap{font-size:10px;} }

/* smaller, centred plate (invite) */
.plate--inset{max-width:450px;margin-left:auto;margin-right:auto;margin-top:36px;}
@media (max-width:560px){ .plate--inset{max-width:360px;} }

/* ---- rules / detail grid ---- */
.rule{height:1px;background:var(--line);margin:52px 0;}
.details{display:grid;grid-template-columns:1fr 1fr;gap:34px 40px;}
.det h4{margin:0 0 8px;font-family:var(--mono);font-size:10px;font-weight:500;letter-spacing:.30em;color:var(--ink-faint);}
.det p{margin:0;font-family:var(--serif);font-size:18px;line-height:1.45;color:#ece5d6;}
.det p .sub{display:block;font-family:var(--mono);font-size:11px;letter-spacing:.10em;color:var(--ink-soft);margin-top:5px;}
@media (max-width:560px){ .details{grid-template-columns:1fr;} }

/* ---- getting there ---- */
.section-label{font-family:var(--mono);font-size:11px;letter-spacing:.30em;color:var(--ink-soft);margin-bottom:22px;}
.addr{font-family:var(--serif);font-size:22px;line-height:1.4;color:var(--ink);margin:0 0 6px;}
.addr-line{font-family:var(--mono);font-size:12px;letter-spacing:.12em;color:var(--ink-soft);}
.getting-note{font-family:var(--serif);font-size:17px;font-style:italic;color:var(--ink-soft);line-height:1.55;margin:18px 0 0;max-width:46ch;}
.maplink{display:inline-block;margin-top:28px;font-family:var(--mono);font-size:11px;letter-spacing:.20em;color:var(--ink);text-decoration:none;border-bottom:1px solid var(--brass);padding-bottom:4px;}
.maplink:hover{color:var(--brass);}

/* ---- RSVP ---- */
.rsvp{padding-bottom:24px;}
.rsvp-card{border:1px solid var(--line);background:rgba(241,235,223,.02);padding:32px 28px;}
@media (max-width:560px){ .rsvp-card{padding:24px 18px;} }
.rsvp-h{font-family:var(--serif);font-style:italic;font-size:28px;color:var(--ink);margin:0 0 6px;}
.rsvp-sub{font-family:var(--mono);font-size:11px;letter-spacing:.18em;color:var(--ink-soft);margin-bottom:26px;}

.banner{
  border:1px solid var(--brass);background:rgba(200,169,106,.08);color:#ece5d6;
  font-family:var(--serif);font-size:16px;line-height:1.5;padding:16px 18px;margin-bottom:24px;
}

/* form bits */
fieldset.choice{border:none;margin:0 0 6px;padding:0;}
fieldset.choice legend{padding:0;}
.lab{display:block;font-family:var(--mono);font-size:10px;letter-spacing:.24em;color:var(--ink-faint);margin-bottom:10px;}
label.fld{display:block;margin:24px 0 0;}
label.fld .hint{font-family:var(--serif);font-style:italic;letter-spacing:0;text-transform:none;color:var(--ink-soft);}

input[type=text],textarea{
  width:100%;background:rgba(0,0,0,.25);border:1px solid var(--line);color:var(--ink);
  font-family:var(--mono);font-size:14px;padding:13px 14px;border-radius:0;outline:none;
}
input[type=text]:focus,textarea:focus{border-color:var(--brass);}
textarea{min-height:72px;resize:vertical;line-height:1.5;}
textarea::placeholder,input::placeholder{color:var(--ink-faint);}

.choice .opt{
  display:flex;align-items:center;gap:13px;padding:15px 18px;margin-bottom:10px;border:1px solid var(--line);
  cursor:pointer;font-family:var(--mono);font-size:13px;letter-spacing:.05em;color:var(--ink);
  transition:border-color .15s,background .15s;
}
.choice .opt:hover{border-color:var(--ink-soft);}
.choice .opt input{position:absolute;opacity:0;pointer-events:none;}
.choice .opt .dot{width:14px;height:14px;border-radius:50%;border:1px solid var(--ink-soft);flex:0 0 auto;transition:.15s;}
.choice .opt.sel{border-color:var(--brass);background:rgba(200,169,106,.06);}
.choice .opt.sel .dot{border-color:var(--brass);background:var(--brass);box-shadow:inset 0 0 0 3px var(--bg);}

.plus-one-field{display:none;margin:0 0 10px;padding:0 0 0 31px;}
.plus-one-field.open{display:block;}

/* ---- menu pre-order ---- */
.menu-intro{margin:6px 0 18px;}
.menu-note{font-family:var(--serif);font-size:15px;font-style:italic;color:var(--ink-soft);margin:8px 0 0;line-height:1.5;}

/* Column grid: dish text + one or two pick columns. CSS var sets column count. */
.menu{--cols:1;}
.menu--two{--cols:2;}
.menu--two.menu--solo{--cols:1;}

.menu-head{display:grid;grid-template-columns:1fr repeat(var(--cols), 52px);
  align-items:end;gap:0 10px;padding:0 4px 10px;margin-bottom:4px;}
.mh-who{font-family:var(--mono);font-size:11px;letter-spacing:.16em;color:var(--brass);
  text-align:center;text-transform:uppercase;justify-self:center;}

.course{margin:0 0 26px;}
.course-label{display:flex;align-items:center;gap:14px;
  font-family:var(--mono);font-size:12px;letter-spacing:.28em;color:var(--brass);
  text-transform:uppercase;margin:0 0 4px;padding:0 0 10px;
  border-bottom:1px solid var(--line);}
.dish-row{display:grid;grid-template-columns:1fr repeat(var(--cols), 52px);
  align-items:center;gap:0 10px;padding:13px 4px;border-bottom:1px solid rgba(241,235,223,.07);}
.dish-row:last-child{border-bottom:none;}
.dish-text{display:flex;flex-direction:column;gap:3px;min-width:0;padding-right:8px;}
.dish-name{font-family:var(--mono);font-size:14px;letter-spacing:.02em;color:var(--ink);line-height:1.35;}
.dish-tags{color:var(--ink-faint);letter-spacing:.06em;}
.dish-note{color:var(--brass);letter-spacing:.02em;}
.dish-desc{font-family:var(--serif);font-size:15px;font-style:italic;color:var(--ink-soft);letter-spacing:0;line-height:1.35;}

/* styled radio cell (replaces the native blue dot) */
.pick{display:flex;align-items:center;justify-content:center;cursor:pointer;justify-self:center;min-height:32px;}
.pick input{position:absolute;opacity:0;width:0;height:0;pointer-events:none;}
.pick .dot{width:20px;height:20px;border-radius:50%;border:1px solid var(--ink-soft);
  transition:border-color .15s, box-shadow .15s, background .15s;}
.pick:hover .dot{border-color:var(--ink);}
.pick input:checked + .dot{border-color:var(--brass);background:var(--brass);
  box-shadow:inset 0 0 0 5px var(--bg);}
.pick input:focus-visible + .dot{outline:2px solid var(--brass);outline-offset:2px;}

.menu-key{font-family:var(--mono);font-size:10px;letter-spacing:.10em;color:var(--ink-faint);
  text-align:center;margin:22px 0 0;line-height:1.8;}
.menu-key strong{color:var(--ink-soft);font-weight:500;}

.btn{
  width:100%;margin-top:24px;padding:17px 0;background:var(--brass);color:#1a1206;border:none;
  font-family:var(--mono);font-size:12px;font-weight:500;letter-spacing:.28em;cursor:pointer;transition:filter .15s;
}
.btn:hover{filter:brightness(1.07);}

/* two-panel: RSVP open / back */
[hidden]{display:none !important;}
.rsvp-open{margin-top:8px;}
.rsvp-deadline{font-family:var(--mono);font-size:10px;letter-spacing:.26em;
  color:var(--ink-faint);text-align:center;text-transform:uppercase;margin:14px 0 0;}
.rsvp-back{display:inline-block;background:none;border:none;cursor:pointer;padding:0;margin:0 0 26px;
  font-family:var(--mono);font-size:11px;letter-spacing:.18em;color:var(--ink-soft);
  text-transform:uppercase;transition:color .15s;}
.rsvp-back:hover{color:var(--ink);}

/* footer */
.foot{display:flex;justify-content:space-between;align-items:center;padding:30px 0 64px;
  font-family:var(--mono);font-size:10px;letter-spacing:.26em;color:var(--ink-faint);gap:16px;}
.foot .sign{font-family:"Caveat",cursive;font-size:24px;letter-spacing:0;color:var(--ink-soft);}
@media (max-width:560px){ .foot{flex-direction:column;gap:14px;text-align:center;} }

/* ---- not-found / closed page (shared by closed.ejs) ---- */
.invite--small{max-width:560px;margin:0 auto;padding:120px 40px;text-align:center;}
.invite--small h1{font-family:var(--serif);font-style:italic;font-weight:200;font-size:64px;color:var(--brass);margin:0 0 24px;}
.invite--small .body{font-family:var(--serif);font-size:19px;line-height:1.6;color:#ece5d6;max-width:42ch;margin:0 auto;}
