:root{--ink:#1d2a35;--muted:#66717c;--accent:#547aa5;--accent2:#e6b980;--paper:rgba(255,255,255,.88);--line:#d8dde2;--good:#46785d;--danger:#b44949;--shadow:0 18px 50px rgba(20,35,50,.15)}*{box-sizing:border-box}body{margin:0;font-family:Inter,Segoe UI,Arial,sans-serif;color:var(--ink);min-height:100vh;background:#f5f1e9}.bg-collage{position:fixed;inset:0;background:linear-gradient(rgba(255,255,255,.42),rgba(255,255,255,.55)),url('background-collage.jpg') center/cover no-repeat;z-index:-2}.bg-collage:after{content:"";position:absolute;inset:0;background:radial-gradient(circle at top left,rgba(255,255,255,.2),rgba(255,255,255,.78) 75%)}.app-shell{max-width:1280px;margin:0 auto;padding:28px}.login-card{max-width:440px;margin:9vh auto;background:var(--paper);backdrop-filter:blur(10px);padding:34px;border-radius:28px;box-shadow:var(--shadow);border:1px solid rgba(255,255,255,.75)}.brand{letter-spacing:.18em;text-transform:uppercase;color:var(--accent);font-weight:800;font-size:.85rem}.brand.small{font-size:.72rem}h1,h2,h3{margin:.15rem 0 .75rem}p{line-height:1.4}.muted,.small-note{color:var(--muted)}.small-note{font-size:.8rem}.error{color:var(--danger);font-weight:700}label{display:block;font-weight:700;font-size:.9rem;margin:.65rem 0 .25rem}input,select,textarea{width:100%;border:1px solid var(--line);border-radius:12px;padding:12px 13px;font:inherit;background:white;color:var(--ink)}textarea{resize:vertical}button{border:0;border-radius:12px;padding:11px 16px;font:inherit;font-weight:800;cursor:pointer;background:var(--accent);color:white;box-shadow:0 5px 14px rgba(84,122,165,.24)}button.secondary{background:#eef3f8;color:var(--ink);box-shadow:none;border:1px solid var(--line)}button.ghost{background:transparent;color:var(--ink);box-shadow:none;border:1px solid var(--line)}button.link-btn{background:transparent;color:var(--accent);box-shadow:none;padding:0}.topbar{display:flex;justify-content:space-between;gap:20px;align-items:center;margin-bottom:16px}.top-actions{display:flex;gap:10px;align-items:center}.pill{background:rgba(255,255,255,.82);border:1px solid var(--line);border-radius:999px;padding:9px 13px;font-weight:800}.tabs{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:18px}.tabs button{background:rgba(255,255,255,.76);color:var(--ink);box-shadow:none;border:1px solid var(--line)}.tabs button.active,.filters button.active{background:var(--accent);color:#fff}.view{display:none}.active-view{display:block}.grid{display:grid;gap:18px}.grid.two{grid-template-columns:repeat(2,minmax(0,1fr))}.grid.form-layout{grid-template-columns:360px 1fr}.grid.tight{gap:10px}.card{background:var(--paper);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.75);border-radius:24px;padding:22px;box-shadow:var(--shadow)}.card.wide{min-width:0}.card-head{display:flex;justify-content:space-between;align-items:center;gap:14px}.card-head.wrap{flex-wrap:wrap}.stacked button{margin-top:8px}.button-row,.quick-actions,.filters,.calendar-controls{display:flex;gap:10px;flex-wrap:wrap;align-items:center}.filters button{background:#eef3f8;color:var(--ink);box-shadow:none;border:1px solid var(--line);padding:8px 11px}.inline-select{display:flex;align-items:center;gap:10px;margin:8px 0 14px}.inline-select select{width:auto}.item-list,.compact-list{display:grid;gap:10px}.item{background:rgba(255,255,255,.76);border:1px solid var(--line);border-radius:16px;padding:12px}.item.done{opacity:.62}.item-title{display:flex;justify-content:space-between;gap:12px;font-weight:900}.meta{color:var(--muted);font-size:.86rem;margin-top:4px}.item-actions{display:flex;gap:8px;margin-top:10px}.item-actions button{font-size:.82rem;padding:7px 10px}.check{font-size:1.2rem}.calendar-grid{margin-top:14px}.month-grid{display:grid;grid-template-columns:repeat(7,1fr);border:1px solid var(--line);background:rgba(255,255,255,.75)}.day-name,.date-cell{border:1px solid var(--line);padding:8px;min-height:108px;background:rgba(255,255,255,.45)}.day-name{min-height:0;text-align:center;font-weight:900;background:rgba(84,122,165,.12)}.date-num{font-weight:900}.cal-event{display:block;margin-top:5px;padding:4px 5px;border-radius:7px;background:rgba(84,122,165,.14);font-size:.76rem}.week-list,.day-list,.year-grid{display:grid;gap:10px}.year-grid{grid-template-columns:repeat(4,1fr)}.mini-month{border:1px solid var(--line);border-radius:14px;padding:10px;background:rgba(255,255,255,.65)}@media(max-width:900px){.grid.two,.grid.form-layout{grid-template-columns:1fr}.topbar{align-items:flex-start;flex-direction:column}.app-shell{padding:16px}}@media print{@page{size:landscape;margin:.45in}body{background:#fff}.bg-collage,.tabs,.topbar,.card form,.filters,.button-row,.item-actions,.inline-select,.calendar-controls button{display:none!important}.app-shell{max-width:none;padding:0}.view{display:none!important}.view.active-view{display:block!important}.card{box-shadow:none;border:0;background:#fff;padding:0}.grid,.grid.form-layout,.grid.two{display:block}.item{break-inside:avoid;border:1px solid #999;margin-bottom:8px;background:#fff}.month-grid{height:7.2in}.date-cell{min-height:1.05in}.day-name,.date-cell{border:1px solid #333;background:#fff}.cal-event{border:1px solid #999;background:#fff}.blank-print .cal-event{display:none}.blank-print .date-cell{min-height:1.1in}h1:after{content:"";display:block;border-bottom:2px solid #333;margin-top:8px}}

/* Print refinements added for one-page calendar and task portrait printing */
@media print {
  /* Default print is portrait; named pages below override where supported. */
  @page { size: portrait; margin: .45in; }
  @page pgCalendar { size: landscape; margin: .25in; }
  @page pgTasks { size: portrait; margin: .45in; }

  #calendar { page: pgCalendar; }
  #tasks { page: pgTasks; }

  /* Calendar print: hide the edit form and show a clean centered title line. */
  #calendar .grid.form-layout { display: block !important; }
  #calendar .grid.form-layout > .card:first-child { display: none !important; }
  #calendar .card.wide { display: block !important; }
  #calendar .card-head { display: none !important; }
  #calendar .calendar-controls {
    display: flex !important;
    justify-content: center;
    align-items: baseline;
    gap: 6px;
    margin: 0 0 .12in 0;
    font-size: 14pt;
    font-weight: 900;
    text-align: center;
  }
  #calendar .calendar-controls::before { content: "Our Calendar - "; }
  #calendar .calendar-controls button,
  #calendar .calendar-controls label { display: none !important; }
  #calendarLabel { display: inline !important; }

  /* Make a month view fit on one landscape sheet. */
  #calendar .calendar-grid { margin-top: 0; break-inside: avoid; page-break-inside: avoid; }
  #calendar .month-grid {
    height: 7.45in;
    grid-template-rows: .34in repeat(6, 1fr);
    break-inside: avoid;
    page-break-inside: avoid;
  }
  #calendar .day-name {
    min-height: 0;
    height: .34in;
    padding: 5px 4px;
    font-size: 10pt;
  }
  #calendar .date-cell {
    min-height: 0;
    padding: 5px 6px;
    font-size: 9.5pt;
    overflow: hidden;
  }
  #calendar .date-num { font-size: 10pt; }
  #calendar .cal-event { font-size: 8pt; line-height: 1.15; padding: 2px 3px; }
  #calendar h1:after { display: none; }

  /* Task printouts should be simple portrait lists. */
  #tasks .grid.form-layout > .card:first-child { display: none !important; }
  #tasks .card-head { display: block !important; }
  #tasks .card-head h2 { text-align: center; margin-bottom: .18in; }
  #tasks .filters, #tasks .inline-select { display: none !important; }
}

/* Calendar event buttons: click to edit */
button.cal-event {
  width: 100%;
  text-align: left;
  border: 0;
  box-shadow: none;
  color: var(--ink);
  cursor: pointer;
}
button.cal-event:hover {
  outline: 2px solid rgba(84,122,165,.35);
}
@media print {
  button.cal-event { cursor: default; }
  button.cal-event:hover { outline: none; }
}


/* v5 mobile and tablet refinements */
html { -webkit-text-size-adjust: 100%; }
button, input, select, textarea { font-size: 16px; }
button, .tabs button, .filters button { min-height: 44px; }
input, select { min-height: 46px; }
textarea { min-height: 92px; }
.calendar-grid { overflow-x: auto; -webkit-overflow-scrolling: touch; }

@media (hover: none) {
  button.cal-event:hover { outline: none; }
  button.cal-event:active { outline: 2px solid rgba(84,122,165,.45); }
}

@media (max-width: 760px) {
  body { font-size: 16px; }
  .bg-collage { background-position: center top; }
  .app-shell { padding: calc(12px + env(safe-area-inset-top)) 12px calc(18px + env(safe-area-inset-bottom)); }
  .login-card { margin: 5vh auto; padding: 24px; border-radius: 22px; }
  .topbar { gap: 12px; margin-bottom: 12px; }
  .topbar h1 { font-size: 1.55rem; }
  .top-actions { width: 100%; display: grid; grid-template-columns: 1fr 1fr; gap: 8px; }
  .top-actions .pill { grid-column: 1 / -1; text-align: center; }
  .tabs { display: grid; grid-template-columns: repeat(5, minmax(0, 1fr)); gap: 6px; position: sticky; top: 0; z-index: 5; padding: 6px 0; background: rgba(245,241,233,.92); backdrop-filter: blur(8px); }
  .tabs button { padding: 10px 5px; font-size: .82rem; border-radius: 10px; }
  .card { padding: 16px; border-radius: 20px; }
  .card-head { align-items: flex-start; }
  .button-row { display: grid; grid-template-columns: 1fr 1fr; }
  .quick-actions { display: grid; grid-template-columns: 1fr 1fr; }
  .filters { gap: 6px; }
  .filters button { flex: 1 1 auto; padding: 8px 9px; }
  .inline-select { display: block; }
  .inline-select select { width: 100%; margin-top: 6px; }
  .item-title { display: block; }
  .item-title span:last-child { display: inline-block; margin-top: 4px; }
  .item-actions { display: grid; grid-template-columns: repeat(3, 1fr); }
  .calendar-controls { gap: 6px; }
  .calendar-controls button { flex: 1 1 auto; }
  .calendar-controls label { width: 100%; }
  .month-grid { min-width: 720px; }
  .day-name, .date-cell { padding: 7px; }
  .date-cell { min-height: 96px; }
  .year-grid { grid-template-columns: 1fr 1fr; }
}

@media (max-width: 430px) {
  .tabs button { font-size: .76rem; padding-left: 3px; padding-right: 3px; }
  .quick-actions, .button-row { grid-template-columns: 1fr; }
  .item-actions { grid-template-columns: 1fr; }
  .month-grid { min-width: 660px; }
  .year-grid { grid-template-columns: 1fr; }
}
