/* ============================================================
   CabinKept — evening-lake design world
   Dials: pine green + lake-water blue + weathered timber +
   campfire cream; friendly slab display (Zilla Slab) + clean
   rounded body (Nunito Sans); camp-badge/patch shape language
   (stitched borders, scalloped badges for finished checklists);
   loon mascot ("Louie") + cabin-with-one-lit-window brand mark;
   UNHURRIED motion tempo; ambient wash = evening lake light.
   Signature: the fair-turns view — nights as gentle stacked
   tokens in NEUTRAL member tones. No red anywhere in this world
   (warmth over blame); warnings use ember amber. No emoji in
   chrome. Accessibility floor: focus rings, contrast,
   reduced-motion respected everywhere.
   ============================================================ */

:root {
  --ck-night: #16303f;       /* evening lake — deep dusk blue */
  --ck-night-2: #1f4254;     /* lighter dusk panel */
  --ck-night-3: #2a566c;     /* hover dusk */
  --ck-lake: #3d7a99;        /* lake-water blue */
  --ck-lake-deep: #275d77;
  --ck-lake-soft: #e0edf3;
  --ck-pine: #24583f;        /* pine green */
  --ck-pine-deep: #183f2c;
  --ck-pine-soft: #e2efe6;
  --ck-timber: #7d5f43;      /* weathered timber */
  --ck-timber-deep: #5f4730;
  --ck-timber-soft: #efe5d6;
  --ck-ember: #e8a13d;       /* campfire glow — the lit window */
  --ck-ember-deep: #a96f14;  /* fills / borders / large text only */
  --ck-ember-text: #8a5a10;  /* small ember text — WCAG AA on lake-soft (4.95:1) + ember-soft (5.14:1) */
  --ck-ember-soft: #fbeed2;
  --ck-cream: #faf4e8;       /* campfire cream canvas */
  --ck-paper: #fffcf4;
  --ck-ink: #253038;
  --ck-ink-soft: #55636d;
  --ck-line: rgba(37, 48, 56, .14);
  --ck-radius: 16px;
  --ck-shadow: 0 2px 6px rgba(22, 48, 63, .10), 0 14px 34px rgba(22, 48, 63, .12);
  --ck-shadow-sm: 0 1px 3px rgba(22, 48, 63, .14);
  --ck-display: "Zilla Slab", "Rockwell", "Georgia", serif;
  --ck-body: "Nunito Sans", -apple-system, "Segoe UI", sans-serif;
  --ck-calm: 320ms;          /* unhurried */
  --ck-drift: 560ms;
  /* member tones — neutral, warm, NO red, no rank meaning */
  --ck-m1: #3f6b52; /* pine   */
  --ck-m2: #4a7d96; /* lake   */
  --ck-m3: #8a6d4f; /* timber */
  --ck-m4: #7c8450; /* moss   */
  --ck-m5: #5f6b7a; /* slate  */
  --ck-m6: #9a8a5e; /* sand   */
  --ck-m7: #7a6b8a; /* heather*/
  --ck-m8: #557a72; /* spruce */
}

* { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; }
body {
  margin: 0;
  font-family: var(--ck-body);
  font-size: 16px;
  line-height: 1.6;
  color: var(--ck-ink);
  background: var(--ck-cream);
  font-variant-numeric: tabular-nums;
}
img, svg { max-width: 100%; }
button { font: inherit; cursor: pointer; }
input, select, textarea { font: inherit; color: inherit; }
a { color: var(--ck-lake-deep); }
h1, h2, h3, h4 { font-family: var(--ck-display); line-height: 1.12; margin: 0 0 .4em; letter-spacing: .005em; font-weight: 600; }

:focus-visible { outline: 3px solid var(--ck-ember); outline-offset: 2px; border-radius: 4px; }
.ck-skip {
  position: absolute; left: -9999px; top: 0; z-index: 200;
  background: var(--ck-ember); color: var(--ck-ink); padding: 10px 16px; font-weight: 700;
}
.ck-skip:focus { left: 12px; top: 12px; }

.ck-hidden { display: none !important; }
.ck-wrap { max-width: 1080px; margin: 0 auto; padding: 0 20px; }

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation-duration: 0.001s !important; transition-duration: 0.001s !important; }
}

/* ---------- ambient depth: evening lake light on the app shell ----------
   (wash lives ON the shell element — a fixed ::before gets occluded) */
#ck-app {
  min-height: 100vh;
  background:
    radial-gradient(1100px 400px at 78% -90px, rgba(232, 161, 61, .10), transparent 70%),
    radial-gradient(900px 420px at 8% 30px, rgba(61, 122, 153, .10), transparent 65%),
    linear-gradient(180deg, rgba(22, 48, 63, .05), transparent 340px),
    var(--ck-cream);
}

/* ============================ BUTTONS ============================ */
.ck-btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  border: 0; border-radius: 12px; padding: 12px 22px;
  font-weight: 800; font-size: 15px; letter-spacing: .01em;
  transition: transform var(--ck-calm) ease, box-shadow var(--ck-calm) ease, background var(--ck-calm) ease;
  text-decoration: none;
}
.ck-btn:active { transform: translateY(1px) scale(.995); }
.ck-btn--pine { background: var(--ck-pine); color: #fff; box-shadow: var(--ck-shadow-sm); }
.ck-btn--pine:hover { background: var(--ck-pine-deep); }
.ck-btn--ember { background: var(--ck-ember); color: #3a2a10; box-shadow: var(--ck-shadow-sm); }
.ck-btn--ember:hover { background: #db9126; }
.ck-btn--lake { background: var(--ck-night-2); color: var(--ck-cream); }
.ck-btn--lake:hover { background: var(--ck-night-3); }
.ck-btn--ghost { background: transparent; color: var(--ck-ink); border: 2px solid var(--ck-line); }
.ck-btn--ghost:hover { border-color: var(--ck-ink-soft); }
.ck-btn--sm { padding: 8px 14px; font-size: 13.5px; }
.ck-btn--lg { padding: 15px 30px; font-size: 17px; }
.ck-btn[disabled] { opacity: .5; cursor: not-allowed; }

/* ============================ LANDING ============================ */
.cl-nav { background: var(--ck-night); color: var(--ck-cream); position: sticky; top: 0; z-index: 50; }
.cl-nav__in { display: flex; align-items: center; gap: 20px; padding: 12px 0; }
.cl-brand { display: flex; align-items: center; gap: 11px; text-decoration: none; color: inherit; }
.cl-brand__mark { width: 42px; height: 42px; flex: none; }
.cl-brand__name { font-family: var(--ck-display); font-weight: 700; font-size: 25px; letter-spacing: .01em; }
.cl-brand__name b { color: var(--ck-ember); font-weight: 700; }
.cl-brand__tag { display: block; font-size: 11.5px; color: rgba(250, 244, 232, .72); margin-top: -3px; }
.cl-nav__links { display: flex; gap: 20px; margin-left: auto; }
.cl-nav__links a { color: rgba(250, 244, 232, .88); text-decoration: none; font-size: 14.5px; font-weight: 700; }
.cl-nav__links a:hover { color: var(--ck-ember); }
@media (max-width: 800px) { .cl-nav__links { display: none; } }

.cl-hero {
  background:
    radial-gradient(950px 420px at 12% -5%, rgba(36, 88, 63, .38), transparent 62%),
    radial-gradient(720px 340px at 88% 8%, rgba(232, 161, 61, .16), transparent 60%),
    linear-gradient(180deg, var(--ck-night) 0%, #1d4254 66%, var(--ck-lake-deep) 130%);
  color: var(--ck-cream);
  overflow: hidden;
}
.cl-hero__grid { display: grid; grid-template-columns: 1.02fr .98fr; gap: 40px; align-items: center; padding: 66px 0 58px; }
@media (max-width: 880px) { .cl-hero__grid { grid-template-columns: 1fr; padding: 44px 0 36px; } }
.cl-kicker {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--ck-display); letter-spacing: .1em; text-transform: uppercase;
  font-size: 13px; font-weight: 600; color: var(--ck-ember);
}
.cl-h1 { font-size: clamp(40px, 5.8vw, 62px); font-weight: 700; margin: 12px 0 14px; }
.cl-h1 em { font-style: normal; color: var(--ck-ember); }
.cl-lede { font-size: 18px; line-height: 1.65; color: rgba(250, 244, 232, .92); max-width: 34em; margin: 0 0 22px; }
.cl-cta-row { display: flex; gap: 14px; flex-wrap: wrap; align-items: center; }
.cl-hero__note { margin-top: 14px; font-size: 13.5px; color: rgba(250, 244, 232, .68); }
.cl-hero__media { position: relative; }
.cl-hero__photo {
  display: block; width: 100%; height: auto; border-radius: 18px;
  box-shadow: 0 6px 16px rgba(10, 24, 33, .35), 0 22px 48px rgba(10, 24, 33, .35);
  border: 1px solid rgba(250, 244, 232, .18);
}
.cl-hero__pin {
  position: absolute; left: -14px; bottom: -22px; width: min(250px, 58%); height: auto;
  filter: drop-shadow(0 10px 22px rgba(10, 24, 33, .45));
}
@media (max-width: 880px) { .cl-hero__pin { left: 4px; bottom: -16px; } .cl-hero__media { margin-bottom: 26px; } }

.cl-strip { background: var(--ck-pine-deep); color: var(--ck-cream); }
.cl-strip ul { display: grid; grid-template-columns: repeat(4, 1fr); gap: 14px; list-style: none; margin: 0; padding: 18px 0; }
@media (max-width: 860px) { .cl-strip ul { grid-template-columns: repeat(2, 1fr); } }
.cl-strip li { display: flex; gap: 10px; align-items: flex-start; font-size: 14px; line-height: 1.45; }
.cl-strip li svg { width: 26px; height: 26px; flex: none; margin-top: 2px; }
.cl-strip b { display: block; font-family: var(--ck-display); font-size: 17px; letter-spacing: .02em; }

.cl-sec { padding: 64px 0; }
.cl-sec--night { background: var(--ck-night); color: var(--ck-cream); }
.cl-sec--paper { background: var(--ck-paper); }
.cl-h2 { font-size: clamp(30px, 4vw, 42px); font-weight: 700; }
.cl-h2 em { font-style: normal; color: var(--ck-pine); }
.cl-sec--night .cl-h2 em { color: var(--ck-ember); }
.cl-center { text-align: center; }
.cl-sub { color: var(--ck-ink-soft); max-width: 48em; margin: 0 auto 8px; }
.cl-sec--night .cl-sub { color: rgba(250, 244, 232, .8); }

/* patch section kicker */
.cl-patch { display: inline-flex; align-items: center; gap: 8px; font-family: var(--ck-display); letter-spacing: .1em; text-transform: uppercase; font-size: 12.5px; font-weight: 600; color: var(--ck-pine-deep); }
.cl-sec--night .cl-patch { color: var(--ck-ember); }
.cl-patch svg { width: 18px; height: 18px; }

.cl-steps { display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px; margin-top: 34px; }
@media (max-width: 820px) { .cl-steps { grid-template-columns: 1fr; } }
.cl-step { background: var(--ck-paper); border: 1px solid var(--ck-line); border-radius: var(--ck-radius); padding: 24px; box-shadow: var(--ck-shadow-sm); }
.cl-step__n { font-family: var(--ck-display); font-size: 42px; font-weight: 700; color: var(--ck-ember-deep); line-height: 1; }
.cl-step h3 { font-size: 21px; margin: 8px 0 6px; }
.cl-step p { margin: 0; color: var(--ck-ink-soft); font-size: 14.5px; }

.cl-features { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; margin-top: 34px; }
@media (max-width: 860px) { .cl-features { grid-template-columns: 1fr 1fr; } }
@media (max-width: 600px) { .cl-features { grid-template-columns: 1fr; } }
.cl-feat { background: rgba(255, 252, 244, .06); border: 1px solid rgba(250, 244, 232, .16); border-radius: var(--ck-radius); padding: 22px; }
.cl-feat svg { width: 34px; height: 34px; }
.cl-feat h3 { font-size: 19px; letter-spacing: .01em; margin: 10px 0 6px; }
.cl-feat p { margin: 0; font-size: 14px; color: rgba(250, 244, 232, .78); }
.cl-feat .cl-badge { margin-top: 10px; }

.cl-badge {
  display: inline-block; font-size: 11.5px; font-weight: 800; letter-spacing: .06em; text-transform: uppercase;
  padding: 3px 10px; border-radius: 999px; background: var(--ck-ember-soft); color: var(--ck-ember-text);
}
.cl-badge--pine { background: var(--ck-pine-soft); color: var(--ck-pine-deep); }

.cl-fair { border-left: 5px solid var(--ck-lake); background: var(--ck-lake-soft); border-radius: 10px; padding: 18px 22px; margin-top: 34px; }
.cl-fair h3 { font-size: 19px; }
.cl-fair p { margin: 0 0 8px; font-size: 14.5px; }
.cl-fair p:last-child { margin: 0; }
.cl-fair--ember { border-left-color: var(--ck-ember-deep); background: var(--ck-ember-soft); }
.cl-fair--pine { border-left-color: var(--ck-pine); background: var(--ck-pine-soft); }

/* pricing */
.cl-tiers { display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px; margin-top: 36px; align-items: stretch; }
@media (max-width: 860px) { .cl-tiers { grid-template-columns: 1fr; } }
.cl-tier { background: var(--ck-paper); border: 1px solid var(--ck-line); border-radius: var(--ck-radius); padding: 26px; display: flex; flex-direction: column; box-shadow: var(--ck-shadow-sm); }
.cl-tier--hero { border: 2px solid var(--ck-pine); box-shadow: var(--ck-shadow); position: relative; }
.cl-tier--hero::before {
  content: "Cabin Pass"; position: absolute; top: -13px; left: 22px;
  background: var(--ck-pine); color: #fff; font-family: var(--ck-display);
  letter-spacing: .06em; font-size: 13px; font-weight: 600; padding: 3px 12px; border-radius: 999px;
}
.cl-tier h3 { font-size: 22px; }
.cl-tier .cl-price { font-family: var(--ck-display); font-size: 44px; font-weight: 700; line-height: 1; margin: 6px 0 2px; }
.cl-tier .cl-price small { font-size: 16px; font-weight: 600; color: var(--ck-ink-soft); }
.cl-tier ul { list-style: none; padding: 0; margin: 14px 0 20px; font-size: 14.5px; display: grid; gap: 8px; }
.cl-tier li { padding-left: 26px; position: relative; }
.cl-tier li::before { /* stitched patch tick */
  content: ""; position: absolute; left: 0; top: 4px; width: 14px; height: 14px; border-radius: 50%;
  background: var(--ck-pine-soft); border: 1.6px dashed var(--ck-pine);
}
.cl-tier li::after {
  content: ""; position: absolute; left: 4px; top: 8px; width: 7px; height: 4px;
  border-left: 2px solid var(--ck-pine-deep); border-bottom: 2px solid var(--ck-pine-deep); transform: rotate(-45deg);
}
.cl-tier .ck-btn { margin-top: auto; }
.cl-tier__note { font-size: 12.5px; color: var(--ck-ink-soft); margin-top: 10px; }

.cl-faq { max-width: 720px; margin: 30px auto 0; }
.cl-faq details { background: var(--ck-paper); border: 1px solid var(--ck-line); border-radius: 12px; padding: 4px 20px; margin-bottom: 10px; }
.cl-faq summary { font-weight: 800; padding: 12px 0; cursor: pointer; font-size: 15.5px; }
.cl-faq p { margin: 0 0 14px; color: var(--ck-ink-soft); font-size: 14.5px; }

.cl-final { background: linear-gradient(180deg, var(--ck-night), #0e2230); color: var(--ck-cream); text-align: center; padding: 70px 0 34px; }
.cl-final .cl-h2 { margin-bottom: 8px; }
.cl-foot { margin-top: 46px; padding-top: 22px; border-top: 1px solid rgba(250, 244, 232, .16); display: flex; flex-wrap: wrap; gap: 8px 22px; justify-content: center; font-size: 13px; color: rgba(250, 244, 232, .66); }
.cl-foot a { color: rgba(250, 244, 232, .85); }
.cl-foot__legal { width: 100%; font-size: 12px; color: rgba(250, 244, 232, .5); margin-top: 6px; }

/* ============================ APP SHELL ============================ */
.ck-header { background: var(--ck-night); color: var(--ck-cream); position: sticky; top: 0; z-index: 40; box-shadow: 0 2px 10px rgba(14, 34, 48, .35); }
.ck-header__in { display: flex; align-items: center; gap: 18px; padding: 10px 0; }
.ck-tabs { display: flex; gap: 4px; margin-left: auto; flex-wrap: wrap; justify-content: flex-end; }
.ck-tabs a {
  color: rgba(250, 244, 232, .84); text-decoration: none; font-family: var(--ck-display);
  letter-spacing: .03em; font-weight: 600; font-size: 15.5px; padding: 8px 12px; border-radius: 10px;
}
.ck-tabs a:hover { background: rgba(250, 244, 232, .1); }
.ck-tabs a.on { background: var(--ck-ember); color: #3a2a10; }
@media (max-width: 880px) { .ck-tabs { display: none; } }

.ck-bottomnav { display: none; }
@media (max-width: 880px) {
  .ck-bottomnav {
    display: grid; grid-template-columns: repeat(5, 1fr); position: fixed; bottom: 0; left: 0; right: 0; z-index: 40;
    background: var(--ck-night); border-top: 1px solid rgba(250, 244, 232, .14); padding: 6px 4px calc(6px + env(safe-area-inset-bottom));
  }
  .ck-bottomnav a { color: rgba(250, 244, 232, .78); text-decoration: none; text-align: center; font-size: 10.5px; font-weight: 700; padding: 4px 2px; border-radius: 8px; }
  .ck-bottomnav a svg { display: block; width: 22px; height: 22px; margin: 0 auto 2px; }
  .ck-bottomnav a.on { color: var(--ck-ember); }
  #ck-main { padding-bottom: 88px !important; }
}

#ck-main { padding: 26px 20px 60px; max-width: 1080px; margin: 0 auto; }
.ck-view-title { display: flex; align-items: baseline; gap: 14px; flex-wrap: wrap; margin-bottom: 4px; }
.ck-view-title h1 { font-size: clamp(29px, 4.4vw, 40px); margin: 0; }
.ck-view-sub { color: var(--ck-ink-soft); margin: 2px 0 22px; font-size: 14.5px; max-width: 58em; }

.ck-card { background: var(--ck-paper); border: 1px solid var(--ck-line); border-radius: var(--ck-radius); padding: 20px; box-shadow: var(--ck-shadow-sm); margin-bottom: 18px; }
.ck-card h2 { font-size: 21px; letter-spacing: .01em; }
.ck-card h3 { font-size: 17px; }

.ck-field { display: grid; gap: 5px; margin-bottom: 14px; }
.ck-field label { display: grid; gap: 5px; font-size: 12.5px; font-weight: 800; letter-spacing: .04em; text-transform: uppercase; color: var(--ck-ink-soft); }
.ck-field label .ck-input { text-transform: none; font-weight: 400; letter-spacing: normal; }
.ck-input, .ck-select {
  border: 1.5px solid var(--ck-line); border-radius: 10px; padding: 10px 14px; background: #fff; width: 100%;
}
.ck-input:focus, .ck-select:focus { border-color: var(--ck-lake); outline: none; box-shadow: 0 0 0 3px rgba(61, 122, 153, .18); }
.ck-row { display: flex; gap: 12px; flex-wrap: wrap; align-items: center; }
.ck-grid2 { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
@media (max-width: 700px) { .ck-grid2 { grid-template-columns: 1fr; } }

.ck-note { font-size: 13px; color: var(--ck-ink-soft); }
.ck-callout { border-left: 4px solid var(--ck-ember-deep); background: var(--ck-ember-soft); border-radius: 8px; padding: 12px 16px; font-size: 13.5px; margin: 12px 0; }
.ck-callout--pine { border-left-color: var(--ck-pine); background: var(--ck-pine-soft); }
.ck-callout--lake { border-left-color: var(--ck-lake); background: var(--ck-lake-soft); }

.ck-chip {
  display: inline-flex; align-items: center; gap: 6px; background: var(--ck-pine-soft); color: var(--ck-pine-deep);
  border-radius: 999px; padding: 5px 13px; font-size: 13.5px; font-weight: 700; border: 0; text-decoration: none;
}
.ck-chip--lake { background: var(--ck-night-2); color: var(--ck-cream); }
.ck-chip--ember { background: var(--ck-ember-soft); color: var(--ck-ember-deep); }
.ck-chip--ghost { background: transparent; border: 1.5px dashed var(--ck-line); color: var(--ck-ink-soft); }
.ck-chip button, .ck-chip .x { background: none; border: 0; color: inherit; font-weight: 800; padding: 0 2px; cursor: pointer; }

/* rule picker (split rules / options) */
.ck-rules { display: grid; grid-template-columns: repeat(2, 1fr); gap: 12px; }
@media (max-width: 700px) { .ck-rules { grid-template-columns: 1fr; } }
.ck-rule {
  text-align: left; background: #fff; border: 2px solid var(--ck-line); border-radius: 12px; padding: 13px 15px;
  transition: border-color var(--ck-calm), background var(--ck-calm);
}
.ck-rule:hover { border-color: var(--ck-lake); }
.ck-rule.on { border-color: var(--ck-pine); background: var(--ck-pine-soft); }
.ck-rule b { font-family: var(--ck-display); letter-spacing: .01em; font-size: 16.5px; display: block; }
.ck-rule span { font-size: 13px; color: var(--ck-ink-soft); }

/* member tone swatch */
.ck-tone { display: inline-block; width: 13px; height: 13px; border-radius: 4px; vertical-align: -1.5px; margin-right: 7px; }

/* ============================ CALENDAR (stays) ============================ */
.ck-cal { user-select: none; }
.ck-cal__head { display: flex; align-items: center; gap: 12px; margin-bottom: 10px; }
.ck-cal__title { font-family: var(--ck-display); font-weight: 700; font-size: 22px; flex: 1; text-align: center; }
.ck-cal table { width: 100%; border-collapse: collapse; table-layout: fixed; }
.ck-cal th { font-size: 11px; font-weight: 800; text-transform: uppercase; letter-spacing: .06em; color: var(--ck-ink-soft); padding: 4px 0; }
.ck-cal td { border: 1px solid var(--ck-line); height: 58px; vertical-align: top; padding: 3px 4px; font-size: 12px; background: #fff; }
.ck-cal td.out { background: transparent; border-color: transparent; }
.ck-cal td.today { box-shadow: inset 0 0 0 2px var(--ck-ember); border-radius: 4px; }
.ck-cal .d { font-weight: 800; color: var(--ck-ink-soft); font-size: 11.5px; }
.ck-cal .marks { display: flex; flex-wrap: wrap; gap: 2px; margin-top: 3px; }
.ck-cal .mark { height: 7px; border-radius: 4px; flex: 1 1 100%; min-width: 12px; }
.ck-cal .mark.req { background: transparent !important; border: 1.6px dashed currentColor; height: 5px; }
@media (max-width: 560px) { .ck-cal td { height: 46px; } }

.ck-staylist { margin-top: 4px; }
.ck-stay { display: grid; grid-template-columns: auto 1fr auto; gap: 12px; align-items: center; padding: 11px 4px; border-bottom: 1px solid var(--ck-line); }
.ck-stay__who b { font-size: 15px; }
.ck-stay__who small { display: block; color: var(--ck-ink-soft); font-size: 12.5px; }
.ck-stay__tag { font-size: 11px; font-weight: 800; letter-spacing: .05em; text-transform: uppercase; padding: 2px 9px; border-radius: 999px; }
.ck-stay__tag.approved { background: var(--ck-pine-soft); color: var(--ck-pine-deep); }
.ck-stay__tag.requested { background: var(--ck-ember-soft); color: var(--ck-ember-deep); }

/* ============================ FAIR TURNS (the signature) ============================
   Nights as gentle stacked tokens, roster order, neutral tones.
   No rankings. No red. Information, never ammunition. */
.ck-fairboard {
  background:
    radial-gradient(1000px 300px at 50% -60px, rgba(232, 161, 61, .12), transparent 70%),
    linear-gradient(180deg, var(--ck-night), var(--ck-night-2));
  color: var(--ck-cream);
  border-radius: var(--ck-radius);
  box-shadow: var(--ck-shadow);
  padding: 24px 22px 20px;
}
.ck-fairboard__head { display: flex; align-items: baseline; gap: 12px; flex-wrap: wrap; margin-bottom: 6px; }
.ck-fairboard__title { font-family: var(--ck-display); font-weight: 700; font-size: 22px; }
.ck-fairboard__sub { font-size: 12.5px; color: rgba(250, 244, 232, .66); }
.ck-fairrow { display: grid; grid-template-columns: 150px 1fr auto; gap: 14px; align-items: center; padding: 12px 0; border-bottom: 1px solid rgba(250, 244, 232, .12); }
.ck-fairrow:last-of-type { border-bottom: 0; }
.ck-fairrow__name { font-weight: 800; font-size: 15px; display: flex; align-items: center; }
.ck-fairrow__name small { display: block; font-weight: 600; font-size: 11.5px; color: rgba(250, 244, 232, .6); }
.ck-tokens { display: flex; flex-wrap: wrap; gap: 4px; align-items: center; }
.ck-token {
  width: 15px; height: 15px; border-radius: 5px;
  animation: ck-token-in var(--ck-drift) ease both;
  animation-delay: var(--delay, 0ms);
}
.ck-token--req { background: transparent !important; border: 1.8px dashed currentColor; opacity: .75; }
@keyframes ck-token-in {
  from { opacity: 0; transform: translateY(7px) scale(.7); }
  to { opacity: 1; transform: translateY(0) scale(1); }
}
.ck-fairrow__n { font-family: var(--ck-display); font-weight: 700; font-size: 26px; line-height: 1; text-align: right; }
.ck-fairrow__n small { display: block; font-family: var(--ck-body); font-weight: 700; font-size: 10px; color: rgba(250, 244, 232, .6); letter-spacing: .06em; text-transform: uppercase; }
.ck-fairboard__even { margin-top: 12px; font-size: 13px; color: rgba(250, 244, 232, .75); border-top: 1px dashed rgba(250, 244, 232, .2); padding-top: 12px; }
@media (max-width: 560px) {
  .ck-fairrow { grid-template-columns: 100px 1fr auto; gap: 9px; }
  .ck-token { width: 11px; height: 11px; border-radius: 4px; }
}

/* holiday rotation */
.ck-holi { display: grid; grid-template-columns: 1fr auto; gap: 10px; align-items: center; padding: 11px 4px; border-bottom: 1px solid var(--ck-line); }
.ck-holi:last-child { border-bottom: 0; }
.ck-holi b { font-size: 15px; }
.ck-holi small { display: block; color: var(--ck-ink-soft); font-size: 12.5px; }
.ck-holi__next { font-weight: 800; font-size: 13.5px; color: var(--ck-lake-deep); background: var(--ck-lake-soft); border-radius: 999px; padding: 5px 14px; }

/* ============================ LEDGER ============================ */
.ck-money-banner {
  border: 2px dashed var(--ck-ember-deep); background: var(--ck-ember-soft); border-radius: 10px;
  padding: 12px 16px; font-size: 13.5px; font-weight: 700; margin-bottom: 18px;
}
.ck-money-stats { display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; margin-bottom: 18px; }
@media (max-width: 700px) { .ck-money-stats { grid-template-columns: 1fr; } }
.ck-stat { background: var(--ck-paper); border: 1px solid var(--ck-line); border-radius: 12px; padding: 14px 16px; }
.ck-stat b { font-family: var(--ck-display); font-size: 29px; font-weight: 700; display: block; line-height: 1.1; }
.ck-stat span { font-size: 11.5px; font-weight: 800; text-transform: uppercase; letter-spacing: .06em; color: var(--ck-ink-soft); }
.ck-stat--good b { color: var(--ck-pine-deep); }
.ck-stat--warm b { color: var(--ck-ember-deep); }

.ck-table { width: 100%; border-collapse: collapse; font-size: 14px; }
.ck-table th { text-align: left; font-family: var(--ck-display); letter-spacing: .04em; font-size: 13px; color: var(--ck-ink-soft); padding: 8px 10px; border-bottom: 2px solid var(--ck-line); }
.ck-table td { padding: 8px 10px; border-bottom: 1px solid var(--ck-line); }
.ck-table .num { text-align: right; }
.ck-table small { color: var(--ck-ink-soft); }

.ck-balance { display: grid; grid-template-columns: 1fr auto; gap: 10px; align-items: center; padding: 11px 4px; border-bottom: 1px solid var(--ck-line); }
.ck-balance:last-child { border-bottom: 0; }
.ck-balance small { display: block; color: var(--ck-ink-soft); font-size: 12.5px; }
.ck-balance__amt { font-family: var(--ck-display); font-weight: 700; font-size: 22px; }
.ck-balance__amt.ahead { color: var(--ck-pine-deep); }
.ck-balance__amt.chip { color: var(--ck-timber-deep); }

.ck-settle { border-left: 4px solid var(--ck-lake); background: var(--ck-lake-soft); border-radius: 10px; padding: 14px 18px; }
.ck-settle li { margin: 4px 0; font-weight: 700; }

/* ============================ OPEN & CLOSE (badges) ============================ */
.ck-check { display: flex; gap: 12px; align-items: flex-start; padding: 9px 4px; border-bottom: 1px solid var(--ck-line); }
.ck-check:last-child { border-bottom: 0; }
.ck-check label { flex: 1; font-size: 14.5px; cursor: pointer; }
.ck-check.done label { color: var(--ck-ink-soft); text-decoration: line-through; text-decoration-color: rgba(37, 48, 56, .35); }
.ck-checkbox {
  appearance: none; -webkit-appearance: none; width: 24px; height: 24px; flex: none; margin-top: 1px;
  border: 2px dashed var(--ck-timber); border-radius: 50%; background: var(--ck-paper);
  display: inline-grid; place-content: center; cursor: pointer;
  transition: background var(--ck-calm), border-color var(--ck-calm);
}
.ck-checkbox:checked { background: var(--ck-pine); border: 2px solid var(--ck-pine-deep); }
.ck-checkbox:checked::before {
  content: ""; width: 10px; height: 6px; border-left: 2.6px solid #fff; border-bottom: 2.6px solid #fff;
  transform: rotate(-45deg) translate(1px, -1px);
}
.ck-progress { height: 12px; border-radius: 999px; background: var(--ck-timber-soft); overflow: hidden; margin: 10px 0 4px; }
.ck-progress b { display: block; height: 100%; background: linear-gradient(90deg, var(--ck-pine), var(--ck-lake)); border-radius: 999px; transition: width var(--ck-drift) ease; }

/* the earned camp badge (scalloped patch) */
.ck-badgewall { display: flex; flex-wrap: wrap; gap: 16px; }
.ck-badge { width: 118px; text-align: center; }
.ck-badge svg { width: 108px; height: 108px; }
.ck-badge small { display: block; font-size: 11.5px; font-weight: 800; color: var(--ck-ink-soft); letter-spacing: .04em; text-transform: uppercase; margin-top: 4px; }
.ck-badge--new svg { animation: ck-badge-in .9s cubic-bezier(.2, 1.4, .4, 1) both; }
@keyframes ck-badge-in { from { transform: scale(.3) rotate(-14deg); opacity: 0; } to { transform: scale(1) rotate(0); opacity: 1; } }

/* duties */
.ck-duty { display: grid; grid-template-columns: 1fr auto auto; gap: 12px; align-items: center; padding: 12px 4px; border-bottom: 1px solid var(--ck-line); }
.ck-duty:last-child { border-bottom: 0; }
.ck-duty b { font-size: 15px; }
.ck-duty small { display: block; color: var(--ck-ink-soft); font-size: 12.5px; }
.ck-duty__next { font-weight: 800; font-size: 13.5px; color: var(--ck-pine-deep); background: var(--ck-pine-soft); border-radius: 999px; padding: 5px 14px; }
@media (max-width: 560px) { .ck-duty { grid-template-columns: 1fr auto; } .ck-duty__next { grid-column: 1 / -1; justify-self: start; } }

/* ============================ COACH ============================ */
.ck-coach-log { display: grid; gap: 12px; margin: 16px 0; }
.ck-msg { max-width: 46em; padding: 12px 16px; border-radius: 14px; font-size: 14.5px; }
.ck-msg--me { background: var(--ck-night-2); color: var(--ck-cream); justify-self: end; border-bottom-right-radius: 4px; }
.ck-msg--coach { background: var(--ck-paper); border: 1px solid var(--ck-line); border-bottom-left-radius: 4px; box-shadow: var(--ck-shadow-sm); }
.ck-msg--coach .ck-cite { margin-top: 10px; padding-top: 8px; border-top: 1px dashed var(--ck-line); font-size: 12px; color: var(--ck-ink-soft); }
.ck-grade { display: inline-block; font-weight: 800; font-size: 10.5px; border-radius: 4px; padding: 1px 6px; margin-right: 6px; vertical-align: 1px; }
.ck-grade--A { background: var(--ck-pine-soft); color: var(--ck-pine-deep); }
.ck-grade--B { background: var(--ck-lake-soft); color: var(--ck-lake-deep); }
.ck-grade--C { background: var(--ck-timber-soft); color: var(--ck-timber-deep); }
.ck-coach-form { display: flex; gap: 10px; }
.ck-coach-form input { flex: 1; }
.ck-suggest { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 10px; }

/* mascot corner (Louie the loon) */
.ck-louie { display: flex; align-items: center; gap: 14px; }
.ck-louie svg { width: 78px; height: 78px; flex: none; }
.ck-louie p { font-size: 13.5px; color: var(--ck-ink-soft); margin: 0; max-width: 42em; }

/* ============================ TOAST + REWARD ============================ */
.ck-toast {
  position: fixed; bottom: 24px; left: 50%; transform: translateX(-50%) translateY(20px);
  background: var(--ck-night); color: var(--ck-cream); border-radius: 999px; padding: 11px 22px;
  font-size: 14px; font-weight: 700; box-shadow: var(--ck-shadow); opacity: 0; pointer-events: none;
  transition: opacity var(--ck-calm), transform var(--ck-calm); z-index: 90; max-width: min(92vw, 480px); text-align: center;
}
.ck-toast.show { opacity: 1; transform: translateX(-50%) translateY(0); }

/* reward beat: campfire embers drifting UP — unhurried, warm */
.ck-embers { position: fixed; inset: 0; pointer-events: none; z-index: 95; overflow: hidden; }
.ck-embers i {
  position: absolute; bottom: -12px; width: 7px; height: 7px; border-radius: 50%;
  background: var(--ck-ember);
  box-shadow: 0 0 8px 2px rgba(232, 161, 61, .5);
  animation: ck-rise ease-out both;
}
@keyframes ck-rise {
  0% { transform: translate(0, 0) scale(1); opacity: 0; }
  12% { opacity: 1; }
  100% { transform: translate(var(--driftx, 0), -104vh) scale(.4); opacity: 0; }
}

.ck-tick { display: inline-block; }

/* welcome / first-win banner */
.ck-hearth {
  text-align: center; background: linear-gradient(180deg, var(--ck-night), var(--ck-night-2)); color: var(--ck-cream); border-radius: var(--ck-radius);
  padding: 26px 20px; margin-bottom: 18px; position: relative; overflow: hidden;
}
.ck-hearth::after {
  content: ""; position: absolute; inset: 0;
  background: radial-gradient(500px 200px at 50% 100%, rgba(232, 161, 61, .22), transparent 70%);
  pointer-events: none;
}
.ck-hearth h2 { font-size: 28px; color: var(--ck-ember); margin: 0 0 4px; }
.ck-hearth p { margin: 0; color: rgba(250, 244, 232, .85); position: relative; }

/* upgrade panel */
.ck-upgrade { border: 2px solid var(--ck-pine); border-radius: var(--ck-radius); background: var(--ck-pine-soft); padding: 20px; }
.ck-upgrade h3 { font-size: 20px; }

/* ===== A4T audience layer: capture · consent · share · cross-sell ===== */
/* Landing-page mount for the consented capture card (sits on the dark final CTA). */
.cl-capture { max-width: 560px; margin: 30px auto 0; text-align: left; }
.cl-capture .ck-capture { box-shadow: var(--ck-shadow); }
.ck-capture { border: 1px solid var(--ck-lake); background: linear-gradient(180deg, var(--ck-lake-soft), var(--ck-paper)); }
.ck-capture h2 { color: var(--ck-lake-deep); }
.ck-capture--done { border-color: var(--ck-pine); background: var(--ck-pine-soft); }
.ck-capture--done h2 { color: var(--ck-pine-deep); }
.ck-capture__form { margin-top: 4px; }
.ck-consent {
  display: flex; align-items: flex-start; gap: 10px; margin: 10px 0; font-size: 14px;
  color: var(--ck-ink-soft); line-height: 1.4; cursor: pointer;
}
.ck-consent input[type="checkbox"] { margin-top: 2px; width: 18px; height: 18px; flex: 0 0 auto; accent-color: var(--ck-pine); cursor: pointer; }
.ck-capture__msg { margin: 8px 0 0; font-size: 13.5px; font-weight: 700; color: var(--ck-pine-deep); min-height: 1em; }
.ck-capture__msg.err { color: var(--ck-ember-text); }
.ck-capture__fine { margin-top: 12px; font-size: 12.5px; }

.ck-share { border: 1px solid var(--ck-line); }
.ck-share h2 { color: var(--ck-pine); }

.a4t-crosssell {
  margin-top: 22px; padding: 20px; border-radius: var(--ck-radius);
  background: var(--ck-pine-soft); border: 1px solid var(--ck-pine);
}
.a4t-crosssell__label {
  margin: 0 0 12px; font-family: var(--ck-display); letter-spacing: .08em; text-transform: uppercase;
  font-size: 12.5px; font-weight: 600; color: var(--ck-pine-deep);
}
.a4t-crosssell__card {
  display: block; background: var(--ck-paper); border: 1px solid var(--ck-line); border-radius: 10px;
  padding: 14px 16px; margin-bottom: 10px; text-decoration: none; color: var(--ck-ink);
  box-shadow: var(--ck-shadow-sm); transition: transform .12s ease, border-color .12s ease;
}
.a4t-crosssell__card:last-child { margin-bottom: 0; }
.a4t-crosssell__card:hover { transform: translateY(-2px); border-color: var(--ck-lake); }
.a4t-crosssell__name { display: block; font-family: var(--ck-display); font-weight: 700; font-size: 16px; color: var(--ck-pine-deep); }
.a4t-crosssell__tag { display: block; font-size: 13.5px; color: var(--ck-ink-soft); margin-top: 2px; }
@media (prefers-reduced-motion: reduce) { .a4t-crosssell__card { transition: none; } }

@media print {
  .cl-nav, .ck-header, .ck-bottomnav, .ck-toast,
  .ck-capture, .ck-share, .a4t-crosssell { display: none !important; }
}
