:root {
    --bg: #ffffff;
    --fg: #1a1a1a;
    --muted: #666;
    --line: #e2e2e2;
    --accent: #2f6b3f;        /* boccia-green */
    --accent-dark: #244f30;
    --card: #f7f7f5;
    --overlay: rgba(20, 20, 20, 0.55);
    --radius: 12px;
    --mono: Consolas, "SF Mono", Menlo, Monaco, "Courier New", monospace;
    --serif: Cambria, "Hoefler Text", Georgia, "Times New Roman", serif;
    --maxw: 1140px;
}

* { box-sizing: border-box; }

html { scroll-behavior: smooth; }

body {
    margin: 0;
    font-family: var(--mono);
    color: var(--fg);
    background: var(--bg);
    line-height: 1.6;
    /* Sticky footer: keep the footer flush to the bottom on short pages. */
    display: flex;
    flex-direction: column;
    min-height: 100vh;
}

img { max-width: 100%; display: block; }

a { color: var(--accent); text-decoration: none; }
a:hover { text-decoration: underline; }

h1, h2, h3 { font-family: var(--serif); line-height: 1.2; }

.skip-link {
    position: absolute; left: -999px; top: 0;
    background: var(--accent); color: #fff; padding: .5rem 1rem; z-index: 100;
}
.skip-link:focus { left: 0; }

/* ---------- Header ---------- */
.site-header {
    border-bottom: 1px solid var(--line);
    position: sticky; top: 0; background: var(--bg); z-index: 50;
}
.header-inner {
    max-width: var(--maxw); margin: 0 auto; padding: .9rem 1.25rem;
    display: flex; align-items: center; justify-content: space-between; gap: 1rem;
}
.brand { display: flex; align-items: center; gap: .9rem; color: var(--fg); }
.brand:hover { text-decoration: none; }
.brand-logo { height: 64px; width: auto; }
.brand-name {
    font-family: var(--serif); font-size: 1.5rem; font-weight: 700;
    letter-spacing: .04em; text-transform: uppercase;
}
.header-account { display: flex; align-items: center; gap: .85rem; font-size: .95rem; }
.account-name { color: var(--muted); }
.account-link { color: var(--fg); }
.account-link.as-button {
    font-family: var(--mono); font-size: .95rem; border: none; background: none;
    padding: 0; cursor: pointer; color: var(--fg);
}
.account-link.as-button:hover { color: var(--accent); }
.logout-form { display: inline; margin: 0; }

.site-nav {
    max-width: var(--maxw); margin: 0 auto; padding: 0 1.25rem .7rem;
    display: flex; flex-wrap: wrap; gap: 1.5rem;
}
.site-nav a {
    color: var(--fg); font-size: 1.02rem; padding: .2rem 0;
    border-bottom: 2px solid transparent;
}
.site-nav a:hover { color: var(--accent); border-bottom-color: var(--accent); text-decoration: none; }

/* ---------- Messages ---------- */
.messages { max-width: var(--maxw); margin: 1rem auto 0; padding: 0 1.25rem; }
.message {
    padding: .75rem 1rem; border-radius: var(--radius); margin-bottom: .5rem;
    border: 1px solid var(--line);
}
.message.success { background: #e8f5ec; border-color: #b7dcc1; color: var(--accent-dark); }
.message.error { background: #fcebea; border-color: #f3c2bf; color: #8a221c; }

/* ---------- Layout ---------- */
.site-main {
    width: 100%; max-width: var(--maxw); margin: 0 auto; padding: 2rem 1.25rem 3rem;
    flex: 1 0 auto;   /* take up remaining height so the footer sits at the bottom */
}
.page-title { font-size: 2rem; margin: 0 0 1.5rem; }

/* ---------- Home ---------- */
.home-grid {
    display: grid; gap: 1rem;
    grid-template-columns: repeat(2, 1fr);
    grid-template-areas: "upcoming upcoming" "past guestbook";
}
.tile {
    position: relative; border-radius: var(--radius); overflow: hidden;
    background: var(--card); border: 1px solid var(--line); min-height: 260px;
}
.tile--upcoming { grid-area: upcoming; min-height: 360px; }
.tile--past { grid-area: past; }
.tile--guestbook { grid-area: guestbook; }
.tile img { width: 100%; height: 100%; object-fit: cover; position: absolute; inset: 0; }
.tile-caption {
    position: absolute; left: 1rem; bottom: 1rem; right: 1rem;
    background: var(--overlay); color: #fff; padding: 1rem 1.25rem;
    border-radius: 10px; backdrop-filter: blur(2px);
}
.tile-caption .eyebrow { font-size: .8rem; text-transform: uppercase; letter-spacing: .08em; opacity: .85; }
.tile-caption .title { font-family: var(--serif); font-size: 1.6rem; margin: .15rem 0; display: block; color: #fff; }
.tile-caption .meta { font-size: .9rem; opacity: .9; }
.tile-caption a.title:hover { text-decoration: underline; }
.tile--upcoming .tile-caption .title { font-size: 2.1rem; }

/* ---------- Lists (calendar / archive) ---------- */
.entry-list { list-style: none; padding: 0; margin: 0; display: grid; gap: .75rem; }
.entry-item {
    border: 1px solid var(--line); border-radius: var(--radius); padding: 1rem 1.25rem;
    display: flex; justify-content: space-between; align-items: baseline; gap: 1rem;
    background: var(--card);
}
.entry-item:hover { border-color: var(--accent); }
.entry-item .entry-title { font-family: var(--serif); font-size: 1.2rem; color: var(--fg); }
.entry-item .entry-meta { color: var(--muted); font-size: .9rem; white-space: nowrap; }
.empty { color: var(--muted); }

/* ---------- Event detail ---------- */
.article h1 { font-size: 2rem; margin-bottom: .25rem; }
.article .byline { color: var(--muted); margin-top: 0; }
.article .body { margin: 1.5rem 0; }
.article .body p { margin: 0 0 1rem; }
.article .body p:last-child { margin-bottom: 0; }

/* ---------- Image carousel (swipeable) ---------- */
.carousel { position: relative; margin: 1.5rem 0; }
.carousel-track {
    display: flex; overflow-x: auto; scroll-snap-type: x mandatory;
    border-radius: var(--radius); scrollbar-width: none; -webkit-overflow-scrolling: touch;
}
.carousel-track::-webkit-scrollbar { display: none; }
.carousel-slide { flex: 0 0 100%; scroll-snap-align: center; margin: 0; }
.carousel-slide img {
    width: 100%; height: clamp(260px, 46vw, 520px); object-fit: cover;
    border-radius: var(--radius); border: 1px solid var(--line); display: block;
}
.carousel-nav {
    position: absolute; top: 50%; transform: translateY(-50%); z-index: 2;
    width: 44px; height: 44px; border-radius: 50%; border: none; cursor: pointer;
    background: var(--overlay); color: #fff; font-size: 1.2rem; line-height: 1;
    display: flex; align-items: center; justify-content: center;
}
.carousel-nav:hover { background: rgba(20, 20, 20, 0.8); }
.carousel-nav.prev { left: .6rem; }
.carousel-nav.next { right: .6rem; }
.carousel-dots { display: flex; justify-content: center; gap: .5rem; margin-top: .75rem; }
.carousel-dots .dot {
    width: 9px; height: 9px; border-radius: 50%; background: var(--line);
    cursor: pointer; transition: background .2s;
}
.carousel-dots .dot.active { background: var(--accent); }

/* ---------- Timeline dividers (archive / calendar) ---------- */
.timeline-year { margin-bottom: 1rem; }
.divider { display: flex; align-items: center; gap: 1rem; }
.divider::after { content: ""; flex: 1; height: 1px; background: var(--line); }
.divider-year {
    font-family: var(--serif); font-size: 1.4rem; color: var(--fg); margin: 2rem 0 .25rem;
}
.timeline-year:first-child .divider-year { margin-top: 0; }
.divider-month {
    font-family: var(--mono); font-weight: normal; font-size: .8rem; color: var(--muted);
    text-transform: uppercase; letter-spacing: .08em; margin: 1.25rem 0 .6rem;
}
.timeline-year .entry-list { margin-bottom: .5rem; }

/* ---------- Documents ---------- */
.doc-list { list-style: none; padding: 0; margin: 0; display: grid; gap: .6rem; }
.doc-list a {
    display: block; border: 1px solid var(--line); border-radius: var(--radius);
    padding: .9rem 1.1rem; color: var(--fg); background: var(--card);
}
.doc-list a:hover { border-color: var(--accent); text-decoration: none; color: var(--accent); }

/* ---------- About ---------- */
.about-text { max-width: 70ch; font-size: 1.05rem; }
.board-grid {
    display: grid; gap: 1.25rem; margin-top: 2rem;
    grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
}
.board-member { text-align: center; }
.board-member img {
    width: 140px; height: 140px; border-radius: 50%; object-fit: cover; margin: 0 auto .6rem;
    border: 1px solid var(--line); background: var(--card);
}
.board-member .name { font-weight: 700; }
.board-member .role { color: var(--muted); font-size: .9rem; }

/* ---------- Guestbook ---------- */
.guestbook-layout { display: grid; gap: 2rem; grid-template-columns: 1fr 1.4fr; align-items: start; }
.card {
    border: 1px solid var(--line); border-radius: var(--radius); padding: 1.5rem; background: var(--card);
}
.form-field { margin-bottom: 1rem; }
.form-field label { display: block; font-size: .9rem; margin-bottom: .3rem; color: var(--muted); }
.form-field input, .form-field textarea {
    width: 100%; padding: .65rem .8rem; border: 1px solid var(--line); border-radius: 8px;
    font-family: var(--mono); font-size: 1rem; background: #fff;
}
.form-field input:focus, .form-field textarea:focus { outline: 2px solid var(--accent); border-color: var(--accent); }
.btn {
    background: var(--accent); color: #fff; border: none; padding: .7rem 1.4rem;
    border-radius: 8px; font-family: var(--mono); font-size: 1rem; cursor: pointer;
}
.btn:hover { background: var(--accent-dark); text-decoration: none; color: #fff; }
.btn-small { padding: .4rem .8rem; font-size: .9rem; }
.btn-ghost { background: transparent; color: var(--fg); border: 1px solid var(--line); }
.btn-ghost:hover { background: var(--card); color: var(--fg); border-color: var(--accent); }
.btn-danger { background: #b23b32; }
.btn-danger:hover { background: #8a221c; color: #fff; }

/* ---------- Page head with action ---------- */
.page-head { display: flex; align-items: center; justify-content: space-between; gap: 1rem; margin-bottom: 1.5rem; }
.page-head .page-title { margin: 0; }

/* ---------- Article banner + edit toolbar ---------- */
.article-banner { margin: 0 0 1.5rem; }
.article-banner img {
    width: 100%; height: clamp(200px, 38vw, 420px); object-fit: cover;
    border-radius: var(--radius); border: 1px solid var(--line); display: block;
}
.edit-toolbar { display: flex; gap: .6rem; justify-content: flex-end; margin-bottom: 1rem; }

/* ---------- Editor (front-end create/edit) ---------- */
.editor-head { display: flex; align-items: center; justify-content: space-between; gap: 1rem; }
.editor-cancel { color: var(--muted); }
.editor-form { margin-top: 1rem; }
.field-row { display: flex; gap: 1rem; flex-wrap: wrap; }
.field-row .form-field { flex: 1; min-width: 160px; }
.field-row .form-field.grow { flex: 1 1 100%; }
.form-field .hint { color: var(--muted); font-weight: normal; font-size: .8rem; }
.editor-split { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; align-items: start; }
.editor-split textarea {
    width: 100%; min-height: 360px; padding: .8rem; border: 1px solid var(--line);
    border-radius: 8px; font-family: var(--mono); font-size: .95rem; resize: vertical; background: #fff;
}
.editor-pane .preview-label {
    font-size: .8rem; text-transform: uppercase; letter-spacing: .08em; color: var(--muted); margin-bottom: .4rem;
}
.preview-output {
    border: 1px dashed var(--line); border-radius: 8px; padding: .8rem 1rem; min-height: 360px;
    background: var(--card); overflow-wrap: anywhere;
}
.preview-output p { margin: 0 0 1rem; }

/* photo manager */
.photo-manager { display: grid; grid-template-columns: repeat(auto-fill, minmax(150px, 1fr)); gap: .75rem; }
.photo-card {
    position: relative; border: 1px solid var(--line); border-radius: 10px; padding: .5rem;
    background: var(--card); cursor: grab;
}
.photo-card.dragging { opacity: .4; }
.photo-card img { width: 100%; height: 110px; object-fit: cover; border-radius: 6px; }
.photo-card .drag-handle { position: absolute; top: .6rem; left: .6rem; color: #fff; background: var(--overlay); border-radius: 4px; padding: 0 .3rem; font-size: .9rem; }
.photo-card .photo-delete { display: flex; align-items: center; gap: .35rem; font-size: .85rem; margin-top: .4rem; color: var(--muted); cursor: pointer; }
.editor-actions { display: flex; gap: .75rem; margin-top: 1.5rem; }

/* ---------- Confirm delete ---------- */
.confirm-box { max-width: 520px; }
.gb-entry { border-bottom: 1px solid var(--line); padding: 1rem 0; }
.gb-entry:last-child { border-bottom: none; }
.gb-entry .gb-head { font-size: .9rem; color: var(--muted); margin-bottom: .3rem; }
.gb-entry .gb-head strong { color: var(--fg); }
.gb-entry .gb-body { white-space: pre-line; }
/* Honeypot — hidden from humans, visible to naive bots. */
.hp { position: absolute; left: -9999px; width: 1px; height: 1px; overflow: hidden; }

/* ---------- Login ---------- */
.login-wrap { max-width: 380px; margin: 3rem auto; }
.login-wrap .brand-logo { height: 90px; margin: 0 auto 1.5rem; }

/* ---------- Footer ---------- */
.site-footer { border-top: 1px solid var(--line); flex-shrink: 0; }
.footer-inner {
    max-width: var(--maxw); margin: 0 auto; padding: 1.25rem; color: var(--muted);
    display: flex; justify-content: space-between; gap: 1rem; font-size: .9rem;
}

/* ---------- Responsive ---------- */
@media (max-width: 760px) {
    .home-grid { grid-template-columns: 1fr; grid-template-areas: "upcoming" "past" "guestbook"; }
    .guestbook-layout { grid-template-columns: 1fr; }
    .brand-name { font-size: 1.1rem; }
    .brand-logo { height: 48px; }
    .header-inner { flex-wrap: wrap; }
    .footer-inner { flex-direction: column; gap: .25rem; }
    .editor-split { grid-template-columns: 1fr; }
    .editor-split textarea, .preview-output { min-height: 220px; }
}
