/* MoTaing — Flamingos & Monsteras theme
   "Mo" floral green · "Taing" flamingo pink */

:root {
  /* ── Flamingo pinks ─────────────────────── */
  --pink-flamingo: #ff7eb6;
  --pink-coral:    #ffb8d1;
  --pink-hot:      #e91e7a;
  --pink-deep:     #b5145e;
  --pink-pale:     #ffe8f0;
  --pink-blush:    #fff5f9;

  /* ── Monstera greens ─────────────────────── */
  --green-monstera: #2d6e3e;
  --green-deep:     #1a4d2e;
  --green-fresh:    #7fb98a;
  --green-mint:     #c7e8d0;
  --green-pale:     #e8f5ec;

  /* ── Tropical accents ───────────────────── */
  --gold:    #f9c74f;
  --sand:    #fff9ed;
  --water:   #88c5d8;

  /* ── Functional ─────────────────────────── */
  --ink:    #2a1a26;
  --muted:  #8a7a82;
  --line:   #f0e0e7;
  --bad:    #d64545;
  --good:   var(--green-monstera);

  /* Compatibility aliases (older selectors still work) */
  --pink:      var(--pink-flamingo);
  --pink-soft: var(--pink-pale);
  --pink-bg:   var(--pink-blush);
  --magenta:   var(--pink-hot);
  --green:     var(--green-fresh);
  --green-soft:var(--green-mint);
  --green-deep:var(--green-monstera);

  color-scheme: light;
}

*,*::before,*::after { box-sizing: border-box; margin: 0; padding: 0; }
html, body {
  background:
    radial-gradient(ellipse at top left,  var(--green-pale) 0%, transparent 55%),
    radial-gradient(ellipse at bottom right, var(--pink-pale) 0%, transparent 55%),
    var(--sand);
  background-attachment: fixed;
  min-height: 100vh;
}
html { scroll-behavior: smooth; }
section.card { scroll-margin-top: 16px; }
a.stat { color: inherit; text-decoration: none; display: block; cursor: pointer; }
a.stat:hover { text-decoration: none; }
body {
  font: 15px/1.5 -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif;
  color: var(--ink);
  position: relative;
}

/* ── Emoji corner decorations (subtle, behind content) ── */
body::before {
  content: "🌿";
  position: fixed;
  top: 60px; left: -20px;
  font-size: 220px; line-height: 1;
  opacity: 0.10;
  transform: rotate(-22deg);
  pointer-events: none;
  z-index: 0;
  user-select: none;
}
body::after {
  content: "🦩";
  position: fixed;
  bottom: -10px; right: 10px;
  font-size: 180px; line-height: 1;
  opacity: 0.10;
  transform: scaleX(-1);
  pointer-events: none;
  z-index: 0;
  user-select: none;
}

main, .modal-bg { position: relative; z-index: 1; }
nav.shell { position: relative; z-index: 100; }  /* sit above main so dropdowns overlap content */

a { color: var(--pink-hot); text-decoration: none; transition: color .15s; }
a:hover { color: var(--green-monstera); text-decoration: underline; }

/* ── NAV / BRAND ─────────────────────────────────────── */
nav.shell {
  background: rgba(255, 249, 237, 0.92);
  backdrop-filter: blur(12px);
  border-bottom: 3px solid transparent;
  border-image: linear-gradient(90deg, var(--green-monstera) 0%, var(--green-fresh) 35%, var(--pink-flamingo) 65%, var(--pink-hot) 100%) 1;
  padding: 12px 24px;
  display: flex; align-items: center; justify-content: space-between;
  gap: 16px;
}
nav.shell .brand {
  font-family: 'Playfair Display', Georgia, serif;
  font-weight: 900; font-size: 26px;
  letter-spacing: -.02em;
  text-decoration: none;
  display: inline-flex; align-items: baseline;
}
nav.shell .brand .brand-mo {
  color: var(--green-monstera);
  font-style: italic;
}
nav.shell .brand .brand-taing {
  color: var(--pink-flamingo);
}
nav.shell .brand .leaf,
nav.shell .brand .flamingo {
  display: inline-block;
  font-size: 22px;
  margin: 0 4px;
  vertical-align: -2px;
  line-height: 1;
}

nav.shell ul { display: flex; gap: 4px; list-style: none; flex-wrap: wrap; align-items: center; }
nav.shell ul li { display: flex; align-items: center; }
nav.shell ul a {
  display: inline-flex; align-items: center;
  padding: 8px 14px; border-radius: 999px; color: var(--ink);
  font-weight: 600; font-size: 13px; line-height: 1;
  text-transform: uppercase; letter-spacing: .06em;
  transition: all .15s;
}
nav.shell ul a:hover { background: var(--green-pale); color: var(--green-monstera); text-decoration: none; }
nav.shell ul a.active {
  background: linear-gradient(135deg, var(--green-mint), var(--pink-pale));
  color: var(--green-deep);
}

/* Dropdown nav items (Schedule, Settings) */
nav.shell .dropdown { position: relative; }
nav.shell .dd-toggle {
  display: inline-flex; align-items: center; gap: 4px;
  padding: 8px 14px; border-radius: 999px;
  background: transparent; border: none; cursor: pointer;
  color: var(--ink); font-weight: 600; font-size: 13px; line-height: 1;
  text-transform: uppercase; letter-spacing: .06em;
  font-family: inherit; transition: all .15s;
}
nav.shell .dd-toggle:hover { background: var(--green-pale); color: var(--green-monstera); }
nav.shell .dd-toggle.active {
  background: linear-gradient(135deg, var(--green-mint), var(--pink-pale));
  color: var(--green-deep);
}
nav.shell .dd-toggle .caret { font-size: 10px; opacity: .65; transform: translateY(-1px); }
nav.shell .dd-toggle[aria-expanded="true"] .caret { opacity: 1; }
nav.shell .dd-menu {
  position: absolute; top: calc(100% + 6px); left: 0;
  min-width: 160px; padding: 6px;
  background: #fff; border: 1px solid var(--line); border-radius: 12px;
  box-shadow: 0 8px 24px rgba(42, 26, 38, .12);
  display: flex; flex-direction: column; gap: 2px;
  list-style: none; z-index: 50;
}
nav.shell .dd-menu a {
  display: block; padding: 8px 12px; border-radius: 8px;
  font-size: 12px; text-transform: uppercase; letter-spacing: .06em;
  font-weight: 600; color: var(--ink); white-space: nowrap;
}
nav.shell .dd-menu a:hover { background: var(--pink-pale); color: var(--magenta); }
nav.shell .dd-menu a.active { background: var(--green-mint); color: var(--green-deep); }
nav.shell .dd-menu[hidden] { display: none; }

nav.shell .user {
  display: flex; align-items: center; gap: 10px;
  font-size: 13px; color: var(--muted);
}
nav.shell .user button {
  background: transparent; border: 1px solid var(--line);
  border-radius: 999px; padding: 6px 14px;
  font: inherit; cursor: pointer; color: var(--muted);
  transition: all .15s;
}
nav.shell .user button:hover { color: var(--pink-hot); border-color: var(--pink-flamingo); }

main { max-width: 1240px; margin: 0 auto; padding: 24px 20px 80px; }

/* ── LOGIN ──────────────────────────────────────────── */
.login-card {
  max-width: 460px; margin: 8vh auto;
  background:
    radial-gradient(circle at top right, var(--pink-pale) 0%, transparent 70%),
    radial-gradient(circle at bottom left, var(--green-pale) 0%, transparent 70%),
    #fff;
  border: 1px solid var(--green-mint);
  border-radius: 24px;
  padding: 40px 32px 32px;
  box-shadow: 0 10px 40px rgba(45,110,62,.08), 0 4px 12px rgba(255,126,182,.10);
  text-align: center;
  position: relative;
  overflow: hidden;
}
.login-card::before {
  content: "🌴";
  position: absolute;
  top: -16px; right: -10px;
  font-size: 90px; line-height: 1;
  opacity: 0.35;
  transform: rotate(15deg);
  pointer-events: none;
  user-select: none;
}
.login-card::after {
  content: "🦩";
  position: absolute;
  bottom: -16px; left: -10px;
  font-size: 80px; line-height: 1;
  opacity: 0.40;
  transform: scaleX(-1) rotate(-8deg);
  pointer-events: none;
  user-select: none;
}
.login-card .brand-large {
  font-family: 'Playfair Display', Georgia, serif;
  font-size: 42px; font-weight: 900;
  letter-spacing: -.025em;
  margin-bottom: 6px;
  position: relative; z-index: 1;
}
.login-card .brand-large .brand-mo { color: var(--green-monstera); font-style: italic; }
.login-card .brand-large .brand-taing { color: var(--pink-flamingo); }
.login-card .tagline {
  color: var(--muted); font-size: 14px; margin-bottom: 28px;
  position: relative; z-index: 1;
  font-style: italic;
}
.login-card label {
  display: block; text-align: left;
  font-size: 11px; font-weight: 700;
  text-transform: uppercase; letter-spacing: .8px;
  color: var(--green-deep); margin-bottom: 6px;
  position: relative; z-index: 1;
}
.login-card input[type=email],
.login-card input[type=password],
.login-card input[type=text] {
  width: 100%; padding: 14px 16px;
  border: 2px solid var(--green-mint);
  border-radius: 14px;
  font: inherit;
  font-size: 16px;  /* prevent iOS Safari zoom-on-focus */
  margin-bottom: 16px;
  background: rgba(255,255,255,.85);
  position: relative; z-index: 1;
  transition: all .15s;
  box-sizing: border-box;
  -webkit-appearance: none;
}
.login-card input:focus {
  outline: none; border-color: var(--pink-flamingo);
  box-shadow: 0 0 0 4px var(--pink-pale);
}

/* Mobile — tighten paddings + scale brand so card fits a 360px viewport */
@media (max-width: 520px) {
  .login-card {
    margin: 4vh 12px;
    padding: 28px 20px 22px;
    border-radius: 18px;
  }
  .login-card::before { font-size: 64px; top: -10px; right: -6px; }
  .login-card::after  { font-size: 56px; bottom: -10px; left: -6px; }
  .login-card .brand-large { font-size: 34px; }
  .login-card .tagline { font-size: 13px; margin-bottom: 20px; }
  .login-card .footnote { font-size: 11px; }
}
.login-card button.primary {
  width: 100%; padding: 14px;
  background: linear-gradient(135deg, var(--pink-flamingo) 0%, var(--pink-hot) 100%);
  color: #fff; font: inherit; font-weight: 700;
  border: none; border-radius: 14px;
  cursor: pointer; font-size: 14px;
  letter-spacing: .04em;
  position: relative; z-index: 1;
  box-shadow: 0 4px 12px rgba(255,126,182,.35);
  transition: all .15s;
}
.login-card button.primary:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 20px rgba(255,126,182,.5);
}
.login-card .msg { margin-top: 14px; padding: 12px 14px; border-radius: 12px; font-size: 13px; position: relative; z-index: 1; }
.login-card .msg.ok  { background: var(--green-mint); color: var(--green-deep); }
.login-card .msg.err { background: #ffe3e3; color: var(--bad); }
.login-card .footnote { font-size: 11px; color: var(--muted); margin-top: 20px; line-height: 1.5; position: relative; z-index: 1; }

/* ── CARDS, BUTTONS, FORMS ──────────────────────────── */
.card {
  background: rgba(255,255,255,0.92);
  border: 1px solid var(--green-mint);
  border-radius: 16px;
  padding: 20px 22px; margin-bottom: 14px;
  box-shadow: 0 2px 8px rgba(45,110,62,.04);
  transition: all .15s;
}
.card:hover { box-shadow: 0 4px 16px rgba(255,126,182,.10); }
.card h2 {
  font-size: 11px; text-transform: uppercase; letter-spacing: 1px;
  color: var(--pink-hot); font-weight: 800; margin-bottom: 14px;
  display: flex; align-items: center; gap: 8px;
}
.card h2::before {
  content: ""; display: inline-block;
  width: 6px; height: 6px; border-radius: 50%;
  background: linear-gradient(135deg, var(--green-monstera), var(--pink-flamingo));
}
.card h3 { font-size: 16px; font-weight: 700; margin-bottom: 8px; }

button.btn, .btn {
  background: rgba(255,255,255,.9);
  border: 1.5px solid var(--green-mint);
  border-radius: 999px;
  padding: 8px 18px; font: inherit;
  cursor: pointer; color: var(--ink);
  font-weight: 600; transition: all .12s;
}
button.btn:hover { border-color: var(--pink-flamingo); color: var(--pink-hot); background: var(--pink-pale); }
button.primary {
  background: linear-gradient(135deg, var(--pink-flamingo) 0%, var(--pink-hot) 100%);
  color: #fff; border: none; font: inherit;
  padding: 9px 20px; border-radius: 999px;
  cursor: pointer; font-weight: 700;
  box-shadow: 0 2px 8px rgba(255,126,182,.30);
  transition: all .15s;
}
button.primary:hover { transform: translateY(-1px); box-shadow: 0 6px 16px rgba(255,126,182,.45); }
button.secondary {
  background: linear-gradient(135deg, var(--green-fresh) 0%, var(--green-monstera) 100%);
  color: #fff; border: none; font: inherit;
  padding: 9px 20px; border-radius: 999px;
  cursor: pointer; font-weight: 700;
  box-shadow: 0 2px 8px rgba(45,110,62,.30);
}
button.secondary:hover { transform: translateY(-1px); box-shadow: 0 6px 16px rgba(45,110,62,.45); }
button.ghost { background: transparent; border: none; color: var(--muted); cursor: pointer; padding: 4px 10px; font: inherit; transition: color .15s; }
button.ghost:hover { color: var(--pink-hot); }
button.danger { color: var(--bad); }
button.tiny { padding: 5px 12px; font-size: 12px; }

input[type=text], input[type=number], input[type=date], input[type=email], select, textarea {
  width: 100%; padding: 9px 14px;
  border: 1.5px solid var(--green-mint);
  border-radius: 10px; font: inherit;
  background: rgba(255,255,255,.9); color: var(--ink);
  transition: all .15s;
}
input:focus, select:focus, textarea:focus {
  outline: none; border-color: var(--pink-flamingo);
  box-shadow: 0 0 0 3px var(--pink-pale);
}
label.field { display: block; margin-bottom: 14px; }
label.field > span {
  display: block; font-size: 11px; font-weight: 700;
  margin-bottom: 5px; color: var(--green-deep);
  text-transform: uppercase; letter-spacing: .8px;
}

/* ── SUMMARY CHIPS ──────────────────────────────────── */
.summary { display: grid; gap: 12px; grid-template-columns: repeat(auto-fit, minmax(170px, 1fr)); margin-bottom: 18px; }
.stat {
  background: rgba(255,255,255,.95);
  border: 1px solid var(--green-mint);
  border-radius: 14px;
  padding: 16px 18px;
  position: relative; overflow: hidden;
  transition: all .15s;
}
.stat::before {
  content: ""; position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: linear-gradient(90deg, var(--green-monstera), var(--pink-flamingo));
  opacity: .7;
}
.stat:hover { transform: translateY(-2px); box-shadow: 0 6px 16px rgba(255,126,182,.10); }
.stat .n {
  font-family: 'Playfair Display', Georgia, serif;
  font-size: 26px; font-weight: 700; color: var(--pink-hot);
  display: block; line-height: 1.1;
}
.stat .n.neg { color: var(--bad); }
.stat .n.pos { color: var(--green-monstera); }
.stat .l { font-size: 10px; text-transform: uppercase; letter-spacing: 1px; color: var(--muted); margin-top: 6px; font-weight: 700; }

/* ── TABLES ────────────────────────────────────────── */
table { width: 100%; border-collapse: collapse; }
table th, table td { padding: 9px 11px; font-size: 13px; text-align: left; border-bottom: 1px solid var(--green-pale); }
table th { font-size: 10px; text-transform: uppercase; letter-spacing: 1px; color: var(--green-deep); font-weight: 800; }
table td.num, table th.num { text-align: right; font-variant-numeric: tabular-nums; font-weight: 600; }
table tr:hover td { background: var(--pink-blush); }
table .cat-pill { display: inline-block; padding: 3px 11px; border-radius: 999px; font-size: 11px; font-weight: 700; }
table .owner-pill { font-size: 10px; color: var(--muted); margin-left: 6px; text-transform: uppercase; letter-spacing: .8px; font-weight: 700; }
table tr.empty td { text-align: center; color: var(--muted); padding: 32px; font-style: italic; }

/* ── CHIPS ─────────────────────────────────────────── */
.chips { display: flex; gap: 6px; flex-wrap: wrap; margin-bottom: 12px; }
.chip {
  background: rgba(255,255,255,.9);
  border: 1.5px solid var(--green-mint);
  border-radius: 999px;
  padding: 5px 14px; font-size: 12px;
  cursor: pointer; user-select: none;
  color: var(--muted); font-weight: 700;
  transition: all .12s;
}
.chip:hover { border-color: var(--pink-flamingo); color: var(--pink-hot); }
.chip.on {
  background: linear-gradient(135deg, var(--pink-flamingo), var(--pink-hot));
  color: #fff; border-color: var(--pink-hot);
}

/* ── MODAL ──────────────────────────────────────────── */
.modal-bg { position: fixed; inset: 0; background: rgba(45,110,62,.30); backdrop-filter: blur(6px); display: none; align-items: flex-start; justify-content: center; padding: 60px 16px; z-index: 100; }
.modal-bg.on { display: flex; }
.modal {
  background: #fff;
  border-radius: 20px;
  padding: 26px 28px;
  width: 100%; max-width: 560px;
  max-height: calc(100vh - 120px); overflow-y: auto;
  box-shadow: 0 30px 60px rgba(0,0,0,.18);
  border: 1px solid var(--green-mint);
}
.modal > header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 16px; }
.modal h3 { margin: 0; font-size: 18px; color: var(--green-deep); font-family: 'Playfair Display', Georgia, serif; }
.modal .close { background: transparent; border: none; cursor: pointer; font-size: 22px; color: var(--muted); transition: color .15s; }
.modal .close:hover { color: var(--pink-hot); }
.modal-actions { display: flex; justify-content: space-between; gap: 8px; margin-top: 20px; padding-top: 16px; border-top: 1px solid var(--green-pale); }
.row2 { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.receipt-drop { border: 2.5px dashed var(--green-fresh); border-radius: 14px; padding: 20px; text-align: center; cursor: pointer; background: var(--green-pale); transition: all .15s; display: block; }
.receipt-drop:hover { border-color: var(--pink-flamingo); background: var(--pink-pale); }
.receipt-drop.dragover { border-color: var(--pink-hot); background: var(--pink-pale); }
.receipt-drop input { display: none; }
.receipt-drop .hint { font-size: 11px; color: var(--muted); margin-top: 6px; }
.receipt-thumb { max-width: 100%; max-height: 200px; margin-top: 10px; border-radius: 12px; border: 1px solid var(--green-mint); }
.ocr-status { font-size: 12px; color: var(--muted); margin-top: 8px; }
.ocr-status.err { color: var(--bad); }
.ocr-status.ok  { color: var(--green-monstera); font-weight: 700; }

/* ── BUCKETS ───────────────────────────────────────── */
.buckets { display: grid; gap: 12px; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); }
.bucket {
  background:
    linear-gradient(135deg, var(--green-pale) 0%, var(--pink-blush) 100%);
  border: 1.5px solid var(--green-mint);
  border-radius: 14px;
  padding: 14px 16px;
}
.bucket h3 { font-size: 15px; color: var(--green-deep); margin: 0 0 8px; font-family: 'Playfair Display', Georgia, serif; }
.bucket .row { display: flex; gap: 10px; align-items: baseline; font-size: 12px; color: var(--muted); margin-bottom: 8px; }
.bucket .row strong { color: var(--ink); font-size: 14px; }
.bucket .bar { height: 10px; background: rgba(255,255,255,.7); border-radius: 999px; overflow: hidden; margin-bottom: 8px; }
.bucket .bar > div { height: 100%; background: linear-gradient(90deg, var(--green-fresh), var(--pink-flamingo)); border-radius: 999px; }
.bucket .bar.over > div { background: linear-gradient(90deg, var(--bad), #ff3b3b); }
.bucket .remaining { font-size: 12px; font-weight: 700; }
.bucket .remaining.over { color: var(--bad); }

.month-picker {
  display: inline-flex; gap: 4px; align-items: center;
  background: rgba(255,255,255,.9); border: 1.5px solid var(--green-mint);
  border-radius: 999px; padding: 4px 8px;
}
.month-picker button { background: transparent; border: none; cursor: pointer; width: 28px; height: 28px; border-radius: 50%; font-size: 16px; color: var(--pink-hot); transition: all .15s; }
.month-picker button:hover { background: var(--pink-pale); }
.month-picker .label { font-weight: 700; min-width: 130px; text-align: center; color: var(--green-deep); }

.hidden { display: none !important; }
.small { font-size: 12px; color: var(--muted); }
.toolbar { display: flex; gap: 10px; align-items: center; flex-wrap: wrap; margin-bottom: 16px; }
.toolbar h1 {
  font-size: 28px;
  font-family: 'Playfair Display', Georgia, serif;
  font-weight: 800;
  letter-spacing: -.01em;
}
.toolbar h1 .em-mo { color: var(--green-monstera); font-style: italic; }
.toolbar h1 .em-pink { color: var(--pink-hot); }
.spacer { flex: 1; }

/* ── Owner color pills (in tables) ───────────────── */
.owner-pill[data-owner="Y"] { color: var(--green-monstera); }
.owner-pill[data-owner="M"] { color: var(--pink-hot); }
.owner-pill[data-owner="Joint"] { color: var(--gold); }

@media (max-width: 700px) {
  nav.shell ul a { font-size: 11px; padding: 6px 10px; }
  main { padding: 16px 12px 60px; }
  nav.shell .brand { font-size: 22px; }
  body::before, body::after { width: 180px; height: 180px; }
}
