/* ===========================================================================
   The Provo River Family Cabin — theme
   Palette grounded in the Provo: deep river-teal, pine, restrained aspen-gold.
   =========================================================================== */

:root {
  --river:      #163F3D;
  --river-2:    #1F5552;
  --river-3:    #2E6E69;
  --pine:       #234D34;
  --aspen:      #E0A53F;
  --aspen-deep: #C6892B;
  --granite:    #5A6660;
  --ink:        #19211D;
  --mist:       #E8EDE8;
  --paper:      #FBFCFA;
  --line:       rgba(25, 33, 29, 0.12);
  --shadow:     0 1px 2px rgba(25,33,29,.05), 0 8px 24px rgba(22,63,61,.08);
  --radius:     14px;
}

* { box-sizing: border-box; }

html { -webkit-text-size-adjust: 100%; }

body {
  margin: 0;
  background: var(--mist);
  color: var(--ink);
  font-family: "Source Sans 3", system-ui, -apple-system, sans-serif;
  font-size: 17px;
  line-height: 1.55;
}

a { color: var(--river-3); }

.muted { color: var(--granite); }

/* ---- Top bar ---------------------------------------------------------- */
.topbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 14px clamp(16px, 4vw, 40px);
  background: var(--river);
  color: #EaF1ee;
}
.brand {
  display: flex;
  align-items: center;
  gap: 12px;
  color: #EAF1EE;
  text-decoration: none;
}
.brand-mark { color: var(--aspen); display: flex; }
.brand-text {
  font-family: "Oswald", sans-serif;
  font-weight: 600;
  font-size: 15px;
  line-height: 1.05;
  letter-spacing: .08em;
  text-transform: uppercase;
}
.brand-text em { font-style: normal; font-weight: 400; color: #BFD3CD; }

.topnav { display: flex; align-items: center; gap: 18px; }
.topnav-link {
  color: #EAF1EE; text-decoration: none; font-weight: 600;
  border-bottom: 2px solid transparent; padding-bottom: 2px;
}
.topnav-link:hover { border-color: var(--aspen); }
.whoami { display: inline-flex; align-items: center; gap: 8px; color: #CFE0DA; font-size: 15px; }
.inline { display: inline; margin: 0; }
.linkbtn {
  background: none; border: none; color: #CFE0DA; cursor: pointer;
  font: inherit; font-size: 15px; padding: 0; text-decoration: underline;
}
.linkbtn:hover { color: #fff; }
.linkbtn.danger { color: #E59A9A; }

.dot { width: 11px; height: 11px; border-radius: 50%; display: inline-block; flex: none; box-shadow: 0 0 0 2px rgba(255,255,255,.5); }

/* ---- Layout ----------------------------------------------------------- */
.wrap {
  max-width: 980px;
  margin: 0 auto;
  padding: clamp(18px, 4vw, 34px) clamp(16px, 4vw, 24px) 60px;
}

/* ---- Hero ------------------------------------------------------------- */
.hero {
  position: relative;
  overflow: hidden;
  border-radius: var(--radius);
  background: linear-gradient(160deg, var(--river) 0%, var(--pine) 100%);
  color: #EEF4F1;
  padding: clamp(28px, 6vw, 56px) clamp(22px, 5vw, 44px);
  box-shadow: var(--shadow);
}
.hero--app { padding-block: clamp(22px, 4vw, 36px); }
.hero-topo {
  position: absolute; inset: 0;
  background-image: url("data:image/svg+xml,%3Csvg%20xmlns%3D%27http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%27%20viewBox%3D%270%200%201200%20400%27%20preserveAspectRatio%3D%27none%27%3E%3Cg%20fill%3D%27none%27%20stroke%3D%27%231F5552%27%20stroke-width%3D%272%27%3E%3Cpath%20d%3D%27M0%2060%20C200%2020%2C400%20100%2C600%2060%20S1000%2020%2C1200%2070%27%2F%3E%3Cpath%20d%3D%27M0%20110%20C220%2070%2C420%20150%2C620%20110%20S1010%2070%2C1200%20120%27%2F%3E%3Cpath%20d%3D%27M0%20160%20C200%20120%2C410%20200%2C610%20160%20S1000%20120%2C1200%20170%27%2F%3E%3Cpath%20d%3D%27M0%20210%20C220%20170%2C420%20250%2C620%20210%20S1010%20170%2C1200%20220%27%2F%3E%3Cpath%20d%3D%27M0%20260%20C200%20220%2C410%20300%2C610%20260%20S1000%20220%2C1200%20270%27%2F%3E%3Cpath%20d%3D%27M0%20310%20C220%20270%2C420%20350%2C620%20310%20S1010%20270%2C1200%20320%27%2F%3E%3Cpath%20d%3D%27M0%20360%20C200%20320%2C410%20400%2C610%20360%20S1000%20320%2C1200%20370%27%2F%3E%3C%2Fg%3E%3C%2Fsvg%3E");
  background-size: cover;
  opacity: .5;
  pointer-events: none;
}
.hero-inner { position: relative; }
.eyebrow {
  font-family: "Oswald", sans-serif;
  text-transform: uppercase;
  letter-spacing: .22em;
  font-size: 13px;
  font-weight: 500;
  color: var(--aspen);
  margin: 0 0 10px;
}
.hero-title {
  font-family: "Oswald", sans-serif;
  font-weight: 600;
  font-size: clamp(34px, 7vw, 58px);
  line-height: 1.02;
  letter-spacing: .01em;
  margin: 0 0 12px;
}
.hero-title--sm { font-size: clamp(26px, 5vw, 40px); }
.hero-sub { margin: 0; font-size: clamp(16px, 2.4vw, 19px); color: #D6E4DE; max-width: 46ch; }

/* ---- Cards ------------------------------------------------------------ */
.card {
  background: var(--paper);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  padding: clamp(18px, 3.5vw, 28px);
  margin-top: 22px;
}
.card.narrow { max-width: 620px; }
.card-title {
  font-family: "Oswald", sans-serif;
  font-weight: 600;
  letter-spacing: .01em;
  margin: 0 0 6px;
  font-size: 24px;
}
.card-title.sm { font-size: 19px; }

/* ---- Legend ----------------------------------------------------------- */
.legend {
  display: flex; flex-wrap: wrap; align-items: center; gap: 10px 16px;
  margin-top: 18px; padding: 0 4px; font-size: 15px;
}
.legend-title {
  font-family: "Oswald", sans-serif; text-transform: uppercase;
  letter-spacing: .14em; font-size: 13px; color: var(--granite);
}

/* ---- Forms ------------------------------------------------------------ */
.field-label {
  display: block;
  font-family: "Oswald", sans-serif;
  text-transform: uppercase;
  letter-spacing: .1em;
  font-size: 12px;
  color: var(--granite);
  margin-bottom: 6px;
}
input[type="text"], input[type="email"] {
  width: 100%;
  padding: 12px 14px;
  border: 1px solid var(--line);
  border-radius: 10px;
  background: #fff;
  font: inherit;
  color: var(--ink);
}
input[type="text"]:focus, input[type="email"]:focus {
  outline: none;
  border-color: var(--river-3);
  box-shadow: 0 0 0 3px rgba(46,110,105,.18);
}
input[type="color"] {
  width: 56px; height: 44px; padding: 4px; border: 1px solid var(--line);
  border-radius: 10px; background: #fff; cursor: pointer;
}
.stack > * + * { margin-top: 16px; }
.grid2 { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.checkrow { display: flex; align-items: flex-end; }
.checkrow label { display: flex; align-items: center; gap: 8px; font-size: 15px; }
.hint { font-size: 14px; color: var(--granite); margin: 8px 0 0; }

.btn {
  display: inline-flex; align-items: center; justify-content: center;
  background: var(--aspen);
  color: #2A1E07;
  border: none;
  border-radius: 10px;
  padding: 12px 22px;
  font-family: "Oswald", sans-serif;
  font-weight: 600;
  letter-spacing: .06em;
  text-transform: uppercase;
  font-size: 14px;
  cursor: pointer;
  text-decoration: none;
  transition: background .15s ease, transform .05s ease;
}
.btn:hover { background: var(--aspen-deep); }
.btn:active { transform: translateY(1px); }

/* ---- Sign-in form ----------------------------------------------------- */
.signin { margin-top: 22px; max-width: 460px; }
.signin-row { display: flex; gap: 10px; }
.signin-row input { flex: 1; }
.hero .field-label { color: #BFD3CD; }
.hero .signin-row input { background: rgba(255,255,255,.96); }

/* ---- Notices ---------------------------------------------------------- */
.notice {
  margin-top: 18px; padding: 14px 16px;
  background: rgba(255,255,255,.12);
  border: 1px solid rgba(255,255,255,.25);
  border-radius: 10px;
  font-size: 15px;
}
.card .notice, .notice.ok, .notice.err {
  background: #EDF4F0; border-color: var(--line); color: var(--ink);
}
.notice.ok  { background: #E8F2E9; border-color: #BcD8C2; }
.notice.err { background: #FBEDE9; border-color: #E7C3B8; color: #7A2E1C; }
.devlink { margin-top: 12px; }
.devlink-label {
  font-family: "Oswald", sans-serif; text-transform: uppercase;
  letter-spacing: .12em; font-size: 12px; margin: 0 0 4px; color: var(--aspen);
}
.devlink a { color: #fff; word-break: break-all; }

/* ---- Member list ------------------------------------------------------ */
.memberlist { list-style: none; margin: 4px 0 0; padding: 0; }
.member {
  display: flex; align-items: center; gap: 12px;
  padding: 12px 4px; border-top: 1px solid var(--line);
  flex-wrap: wrap;
}
.member:first-child { border-top: none; }
.member-name { font-weight: 600; }
.member-email { flex: 1; min-width: 160px; font-size: 15px; }
.tag {
  font-family: "Oswald", sans-serif; font-size: 11px; text-transform: uppercase;
  letter-spacing: .1em; background: var(--river-3); color: #fff;
  padding: 2px 7px; border-radius: 999px; vertical-align: middle;
}

/* ---- Footer ----------------------------------------------------------- */
.footer {
  text-align: center; padding: 28px 16px 40px; color: var(--granite);
  font-size: 14px; display: flex; gap: 10px; justify-content: center; align-items: center;
}
.footer-sep { opacity: .5; }

/* ===========================================================================
   FullCalendar theming
   =========================================================================== */
#calendar { --fc-border-color: var(--line); --fc-today-bg-color: rgba(224,165,63,.12); }
.fc { font-family: "Source Sans 3", sans-serif; }
.fc .fc-toolbar-title {
  font-family: "Oswald", sans-serif; font-weight: 600; letter-spacing: .01em;
  font-size: clamp(20px, 4vw, 26px); color: var(--ink);
}
.fc .fc-button {
  background: var(--river-2); border-color: var(--river-2);
  font-family: "Oswald", sans-serif; text-transform: uppercase;
  letter-spacing: .05em; font-size: 13px; font-weight: 500;
  box-shadow: none;
}
.fc .fc-button:hover { background: var(--river); border-color: var(--river); }
.fc .fc-button:focus { box-shadow: 0 0 0 3px rgba(46,110,105,.25); }
.fc .fc-button-primary:not(:disabled).fc-button-active,
.fc .fc-button-primary:not(:disabled):active { background: var(--river); border-color: var(--river); }
.fc .fc-button .fc-icon { vertical-align: middle; }
.fc .fc-col-header-cell-cushion {
  font-family: "Oswald", sans-serif; text-transform: uppercase;
  letter-spacing: .08em; font-size: 12px; color: var(--granite);
  padding: 8px 4px; text-decoration: none;
}
.fc .fc-daygrid-day-number { color: var(--ink); text-decoration: none; padding: 6px 8px; }
.fc .fc-day-today .fc-daygrid-day-number { color: var(--aspen-deep); font-weight: 700; }
.fc-theme-standard td, .fc-theme-standard th { border-color: var(--line); }
.fc .fc-daygrid-day.fc-day-today { background: var(--fc-today-bg-color); }

/* ---- Small screens ---------------------------------------------------- */
@media (max-width: 560px) {
  body { font-size: 16px; }
  .grid2 { grid-template-columns: 1fr; }
  .signin-row { flex-direction: column; }
  .signin-row .btn { width: 100%; }
  .topnav { gap: 12px; }
  .brand-text { font-size: 13px; }
  .whoami { display: none; }       /* keep the bar tidy on phones */
}

/* ---- Accessibility ---------------------------------------------------- */
:focus-visible { outline: 2px solid var(--aspen); outline-offset: 2px; }
@media (prefers-reduced-motion: reduce) { * { transition: none !important; } }

/* ===========================================================================
   v2 additions — roles, requests, approvals
   =========================================================================== */
select {
  width: 100%; padding: 12px 14px; border: 1px solid var(--line);
  border-radius: 10px; background: #fff; font: inherit; color: var(--ink);
}
select:focus { outline: none; border-color: var(--river-3); box-shadow: 0 0 0 3px rgba(46,110,105,.18); }
.roleform { display: inline-flex; align-items: center; gap: 8px; }
.roleselect { width: auto; padding: 6px 10px; font-size: 14px; }
input[type="number"], input[type="date"] {
  width: 100%; padding: 12px 14px; border: 1px solid var(--line);
  border-radius: 10px; background: #fff; font: inherit; color: var(--ink);
}
input[type="number"]:focus, input[type="date"]:focus {
  outline: none; border-color: var(--river-3); box-shadow: 0 0 0 3px rgba(46,110,105,.18);
}
.grid3 { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 16px; }
.btn.small { padding: 8px 16px; font-size: 13px; }
.page-notice { margin-top: 18px; }

.count {
  display: inline-block; min-width: 20px; text-align: center;
  background: var(--aspen); color: #2A1E07; border-radius: 999px;
  font-size: 12px; padding: 1px 6px; margin-left: 4px; font-weight: 600;
}

.reqlist { list-style: none; margin: 8px 0 0; padding: 0; }
.req {
  display: flex; align-items: center; gap: 12px;
  padding: 14px 4px; border-top: 1px solid var(--line); flex-wrap: wrap;
}
.req:first-child { border-top: none; }
.req-main { flex: 1; min-width: 200px; display: flex; flex-direction: column; gap: 2px; }
.req-dates { font-weight: 600; }
.req-meta { font-size: 14px; }
.req-actions { display: flex; align-items: center; gap: 14px; }

.stat {
  font-family: "Oswald", sans-serif; font-size: 11px; text-transform: uppercase;
  letter-spacing: .1em; padding: 3px 9px; border-radius: 999px; flex: none;
}
.stat--pending  { background: #FAEEDA; color: #854F0B; }
.stat--approved { background: #E8F2E9; color: #27500A; }
.stat--denied   { background: #FBEDE9; color: #7A2E1C; }

/* Pending events on the calendar: dashed outline in the member's color */
.fc .ev-pending .fc-event-main { color: var(--ink); }
.fc .ev-pending { border-style: dashed; border-width: 2px; }

@media (max-width: 560px) {
  .grid3 { grid-template-columns: 1fr; }
  .req-actions { width: 100%; justify-content: flex-end; }
}
