/* Styles (same base) */
*{box-sizing:border-box}
html,body{height:100%}
body{margin:0;font-family:'Inter',system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;color:#222;background:#fffaf4}

.wrap{width:min(1100px,92vw);margin:0 auto}

.site-header,.site-footer{background:linear-gradient(90deg,#f6eadf,#ffe9cc);padding:1rem 0}
.site-header .wrap,.site-footer .wrap{display:flex;align-items:center;justify-content:space-between;gap:1rem}
.title{margin:0;font-size:clamp(1.15rem,2.2vw,1.6rem);font-weight:800;letter-spacing:.2px}
.venmo-top{background:#3d95ce;color:#fff;text-decoration:none;padding:.6rem .9rem;border-radius:10px;font-weight:700;box-shadow:0 4px 10px rgba(6,41,61,.12)}

.card{background:#fff;border:1px solid #ecd7c1;border-radius:14px;padding:clamp(1rem,2vw,1.4rem);margin:clamp(1rem,3vw,1.6rem) 0;box-shadow:0 12px 30px rgba(0,0,0,.04)}

/* HERO (bio) */
.bio-grid{display:grid;grid-template-columns:220px 1fr;gap:1.1rem;align-items:start}
.hero img{width:100%;height:auto;border-radius:12px;object-fit:cover;aspect-ratio:3/4;box-shadow:0 12px 20px rgba(0,0,0,.08)}
.hero .eyebrow{text-transform:uppercase;letter-spacing:.12em;font-weight:800;color:#8a6134;font-size:.8rem}
.hero .cta{display:flex;gap:.6rem;flex-wrap:wrap;margin-top:.6rem}

/* HOW IT WORKS: step cards layout */
#how-it-works > div{display:block;max-width:none}
#how-it-works .steps-grid{
  display:grid;
  grid-template-columns:1fr;
  gap:14px;
  margin:12px 0 6px;
}
@media (min-width:760px){
  #how-it-works .steps-grid{grid-template-columns:repeat(3,1fr)}
}
#how-it-works .step-card{
  background:#fffdf9;
  border:1px solid #ecd7c1;
  border-radius:12px;
  padding:14px 16px;
  box-shadow:0 8px 18px rgba(0,0,0,.05);
}
#how-it-works .step-card h3{margin:6px 0 6px;font-size:1.05rem}
#how-it-works .step-card p{margin:0}
#how-it-works .step-num{
  width:28px;height:28px;display:inline-flex;align-items:center;justify-content:center;
  border-radius:999px;background:#3d95ce;color:#fff;font-weight:800;
  box-shadow:0 6px 14px rgba(61,149,206,.20);
}
#how-it-works .muted{opacity:.85}

@media(max-width:720px){
  .bio-grid{grid-template-columns:1fr}
  .hero img{max-width:240px}
}

/* Calendar */
.legend .chip{display:inline-block;font-size:.85rem;padding:.2rem .55rem;border-radius:999px;background:#f2ece6;border:1px solid #e2d4c6;margin-left:.25rem}
.legend .chip.any{background:#fff6ef;border-color:#f4b87a}
.legend .chip.pledged{background:#eaf7ea;border-color:#a8d1a9}

.grid{display:grid;grid-template-columns:repeat(7,1fr);gap:8px}
.dayname{text-align:center;font-weight:600;color:#7a5b3c;padding:.4rem 0}

.cell{position:relative;min-height:95px;background:#fff;border:1px solid #eee1d4;border-radius:10px;padding:.4rem;display:flex;flex-direction:column;align-items:flex-start;justify-content:flex-start;cursor:pointer;transition:transform .08s ease,box-shadow .15s ease;box-shadow:0 3px 0 rgba(0,0,0,.03)}
.cell:hover{transform:translateY(-1px);box-shadow:0 6px 14px rgba(0,0,0,.06)}
.cell .label{font-weight:700;font-size:.95rem;color:#7a5b3c}
.cell .amount{margin-top:.3rem;font-size:.95rem;opacity:.8}
.cell.any{background:#fffdf9}
.cell.any .amount{font-style:italic;color:#a46e2c}
.cell.pledged{color:#1f5122;border-color:#c4e3c6;background:#f7fff7}
.cell.pledged::before,.cell.pledged::after{content:"";position:absolute;left:8px;right:8px;top:50%;height:2px;background:rgba(31,81,34,.75);transform-origin:center}
.cell.pledged::before{transform:rotate(22deg)}
.cell.pledged::after{transform:rotate(-22deg)}
.cell .badge{position:absolute;top:6px;right:6px;font-size:.75rem;color:#835227;background:#fff1e1;border:1px solid #f4b87a;padding:.15rem .4rem;border-radius:8px}

/* Buttons & dialog */
.button{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.7rem 1rem;border-radius:12px;border:1px solid #1e66af00;background:#3d95ce;color:#fff;font-weight:700;text-decoration:none;cursor:pointer;box-shadow:0 8px 24px rgba(61,149,206,.18)}
.button:hover{filter:brightness(1.05)}
.button-outline{background:#fff;color:#3d95ce;border-color:#3d95ce;box-shadow:none}
.button-text{background:transparent;color:#7a5b3c;border:none;box-shadow:none;font-weight:600;padding-left:.2rem;padding-right:.2rem}
.cta.center{text-align:center;margin-top:1.5rem}

dialog{width:min(560px,92vw);border:none;border-radius:16px;padding:0;box-shadow:0 30px 80px rgba(0,0,0,.35)}
dialog::backdrop{background:rgba(0,0,0,.28)}
#donateForm{padding:1.1rem}
#donateForm h3{margin:.2rem 0 .1rem}
#donateForm p{margin:.25rem 0 .75rem}
.form-row{display:grid;gap:.35rem;margin-bottom:.8rem}
input[type="text"],input[type="number"]{padding:.7rem .8rem;border:1px solid #e1d5c7;border-radius:10px;font-size:1rem;background:#fffdf9}
.actions{display:flex;gap:.6rem;flex-wrap:wrap;margin-top:.5rem}

.tiny{font-size:.84rem;color:#6d6d6d}
.footnote{color:#6d6d6d;font-size:.9rem}
.share-actions{display:flex;gap:.6rem;flex-wrap:wrap}

.site-footer{font-size:.9rem;color:#5e4b38}
/* --- Mobile calendar tuning --- */
@media (max-width: 420px) {
  /* tighten the card a bit so 7 columns fit */
  .calendar.card { padding: 10px 8px; overflow: hidden; }

  /* make columns flexible and reduce gaps */
  .calendar .grid {
    grid-template-columns: repeat(7, minmax(0, 1fr));
    gap: 6px;
    margin-inline: 2px; /* tiny buffer so the last column isn't clipped */
  }

  /* smaller weekday labels */
  .calendar .dayname {
    font-size: 0.85rem;
    padding: .3rem 0;
  }

  /* smaller cells to avoid wrapping */
  .cell {
    min-height: 66px;
    padding: .3rem;
  }
  .cell .label { font-size: .85rem; }
  .cell .amount { font-size: .85rem; }
  .cell .badge {
    top: 4px; right: 4px;
    font-size: .68rem; padding: .1rem .3rem;
  }
}

/* iOS text zoom sanity */
html { -webkit-text-size-adjust: 100%; }
/* --- Mobile calendar: lock 7 columns and tighten spacing --- */
@media (max-width: 430px) {
  /* keep the card compact so 7 columns fit */
  .calendar.card {
    padding: 10px 8px !important;
    overflow: hidden; /* prevent subtle horizontal bleed */
  }

  /* force equal 1fr columns, smaller gaps, no extra margins */
  .calendar .grid {
    grid-template-columns: repeat(7, minmax(0, 1fr)) !important;
    gap: 6px !important;
    margin: 0 !important;
  }

  /* slightly smaller headers for room */
  .calendar .dayname {
    font-size: 0.85rem !important;
    padding: 0.3rem 0 !important;
  }

  /* keep cells tidy */
  .cell {
    min-height: 66px !important;
    padding: 0.32rem !important;
  }
  .cell .label,
  .cell .amount {
    font-size: 0.85rem !important;
    line-height: 1.1;
  }
  .cell .badge {
    top: 4px; right: 4px;
    font-size: 0.68rem; padding: 0.1rem 0.3rem;
  }
}

/* Guard against iOS text auto-zoom shifting widths */
html { -webkit-text-size-adjust: 100%; }
/* === Mobile calendar hard overrides === */
html { -webkit-text-size-adjust: 100%; } /* stop iOS auto-zoom shifts */

/* Phones up to ~iPhone 14/15 width */
@media (max-width: 430px) {
  .calendar.card {
    padding: 10px 6px !important;   /* narrower card padding */
    overflow: hidden;               /* prevent any bleed */
  }

  /* Force 7 equal columns, smaller spacing, add tiny right buffer */
  .calendar .grid {
    grid-template-columns: repeat(7, minmax(0, 1fr)) !important;
    gap: 5px !important;
    margin: 0 !important;
    padding-right: 2px !important;  /* 2px safety so last column never clips */
  }

  .calendar .dayname {
    font-size: 0.84rem !important;
    padding: 0.28rem 0 !important;
    line-height: 1.05 !important;
  }

  .cell {
    min-height: 64px !important;
    padding: 0.30rem !important;
    border-radius: 9px !important;
  }
  .cell .label,
  .cell .amount {
    font-size: 0.84rem !important;
    line-height: 1.1 !important;
  }
  .cell .badge {
    top: 4px; right: 4px;
    font-size: 0.68rem; padding: 0.1rem 0.3rem;
  }
}

/* Extra-tight layout for very narrow phones (SE/mini) */
@media (max-width: 375px) {
  .calendar.card { padding: 10px 4px !important; }
  .calendar .grid { gap: 4px !important; padding-right: 1px !important; }
  .calendar .dayname { font-size: 0.8rem !important; }
  .cell { min-height: 60px !important; }
  .cell .label, .cell .amount { font-size: 0.8rem !important; }
}

