/* Yuritzi Rodriguez Photography — contract portal
   Elegant, soft-neutral palette: ivory, ink, gold, tan. */

:root {
  --ivory: #faf8f4;
  --paper: #ffffff;
  --ink: #1c1a17;
  --ink-soft: #55504a;
  --gold: #b08d3e;
  --gold-light: #d8bd85;
  --tan: #e9e1d3;
  --tan-dark: #d4c7b0;
  --danger: #a4433a;
  --success: #4a7c59;
  --radius: 10px;
  --shadow: 0 2px 14px rgba(40, 32, 16, 0.08);
}

* { box-sizing: border-box; margin: 0; padding: 0; }

body {
  font-family: 'Inter', -apple-system, 'Segoe UI', sans-serif;
  background: var(--ivory);
  color: var(--ink);
  line-height: 1.55;
  min-height: 100vh;
}

h1, h2, h3, .brand { font-family: 'Cormorant Garamond', Georgia, serif; font-weight: 600; }

a { color: var(--gold); }

/* ---------- header / nav ---------- */
.topbar {
  background: var(--paper);
  border-bottom: 1px solid var(--tan);
  padding: 14px 24px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 10px;
}
.brand {
  font-size: 1.35rem;
  letter-spacing: 0.5px;
  color: var(--ink);
  text-decoration: none;
}
.brand em { color: var(--gold); font-style: normal; }
.nav { display: flex; gap: 4px; flex-wrap: wrap; }
.nav a {
  color: var(--ink-soft);
  text-decoration: none;
  padding: 7px 14px;
  border-radius: 6px;
  font-size: 0.9rem;
  letter-spacing: 0.4px;
}
.nav a:hover { background: var(--tan); color: var(--ink); }
.nav a.active { background: var(--ink); color: var(--ivory); }

/* ---------- layout ---------- */
.container { max-width: 1050px; margin: 0 auto; padding: 32px 20px 64px; }
.container.narrow { max-width: 640px; }
.page-title { font-size: 2rem; margin-bottom: 4px; }
.page-sub { color: var(--ink-soft); margin-bottom: 28px; font-size: 0.95rem; }

.card {
  background: var(--paper);
  border: 1px solid var(--tan);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  padding: 26px;
  margin-bottom: 22px;
}
.card h2 { font-size: 1.35rem; margin-bottom: 14px; }

.grid { display: grid; gap: 18px; }
.grid.cols-2 { grid-template-columns: 1fr 1fr; }
.grid.cols-4 { grid-template-columns: repeat(4, 1fr); }
@media (max-width: 760px) {
  .grid.cols-2, .grid.cols-4 { grid-template-columns: 1fr; }
}

/* ---------- stats ---------- */
.stat { text-align: center; padding: 20px 10px; }
.stat .num { font-family: 'Cormorant Garamond', Georgia, serif; font-size: 2.4rem; color: var(--gold); line-height: 1.1; }
.stat .label { color: var(--ink-soft); font-size: 0.82rem; letter-spacing: 1.2px; text-transform: uppercase; }

/* ---------- forms ---------- */
label { display: block; font-size: 0.83rem; letter-spacing: 0.6px; color: var(--ink-soft); margin-bottom: 5px; text-transform: uppercase; }
input[type="text"], input[type="email"], input[type="tel"], input[type="date"],
input[type="password"], input[type="number"], select, textarea {
  width: 100%;
  padding: 11px 13px;
  border: 1px solid var(--tan-dark);
  border-radius: 6px;
  background: #fffdf9;
  font: inherit;
  color: var(--ink);
}
input:focus, select:focus, textarea:focus {
  outline: none;
  border-color: var(--gold);
  box-shadow: 0 0 0 3px rgba(176, 141, 62, 0.15);
}
.field { margin-bottom: 16px; }
textarea { min-height: 90px; resize: vertical; }
.req::after { content: " *"; color: var(--danger); }

/* ---------- buttons ---------- */
.btn {
  display: inline-block;
  border: none;
  cursor: pointer;
  font: inherit;
  font-size: 0.92rem;
  letter-spacing: 0.8px;
  padding: 12px 26px;
  border-radius: 6px;
  background: var(--ink);
  color: var(--ivory);
  text-decoration: none;
  transition: background 0.15s;
}
.btn:hover { background: #3a352e; }
.btn.gold { background: var(--gold); }
.btn.gold:hover { background: #97772f; }
.btn.outline { background: transparent; color: var(--ink); border: 1px solid var(--tan-dark); }
.btn.outline:hover { background: var(--tan); }
.btn.danger { background: transparent; color: var(--danger); border: 1px solid var(--danger); }
.btn.danger:hover { background: #fbeeec; }
.btn.small { padding: 7px 14px; font-size: 0.82rem; }
.btn:disabled { opacity: 0.5; cursor: not-allowed; }

/* ---------- tables ---------- */
table { width: 100%; border-collapse: collapse; font-size: 0.92rem; }
th { text-align: left; font-size: 0.75rem; letter-spacing: 1px; text-transform: uppercase; color: var(--ink-soft); padding: 10px 12px; border-bottom: 2px solid var(--tan); }
td { padding: 12px; border-bottom: 1px solid var(--tan); vertical-align: middle; }
tr:hover td { background: #fdfbf6; }
.table-wrap { overflow-x: auto; }

/* ---------- status badges ---------- */
.badge {
  display: inline-block;
  font-size: 0.72rem;
  letter-spacing: 1px;
  text-transform: uppercase;
  padding: 4px 12px;
  border-radius: 999px;
  border: 1px solid transparent;
}
.badge.Draft     { background: #f1efeb; color: #6b6459; border-color: #ddd6c9; }
.badge.Sent      { background: #eef2f7; color: #3c5a78; border-color: #c8d6e5; }
.badge.Viewed    { background: #fbf3e2; color: #8a6d2f; border-color: #e8d5aa; }
.badge.Signed    { background: #eaf3ed; color: #34613f; border-color: #c4dccb; }
.badge.Completed { background: #1c1a17; color: #e8d5aa; border-color: #1c1a17; }

/* ---------- alerts ---------- */
.alert { padding: 12px 16px; border-radius: 6px; margin-bottom: 16px; font-size: 0.92rem; display: none; }
.alert.show { display: block; }
.alert.error { background: #fbeeec; color: var(--danger); border: 1px solid #ecc9c5; }
.alert.ok { background: #eaf3ed; color: var(--success); border: 1px solid #c4dccb; }

/* ---------- signing page ---------- */
.sign-header {
  text-align: center;
  padding: 34px 20px 26px;
  background: var(--paper);
  border-bottom: 1px solid var(--tan);
}
.sign-header .brand { font-size: 1.9rem; }
.sign-header .tagline { color: var(--ink-soft); font-size: 0.85rem; letter-spacing: 2.5px; text-transform: uppercase; margin-top: 4px; }

.summary-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); gap: 14px; }
.summary-item .k { font-size: 0.72rem; letter-spacing: 1px; text-transform: uppercase; color: var(--ink-soft); }
.summary-item .v { font-size: 0.98rem; }

#pdf-viewer { background: #efeae0; border: 1px solid var(--tan-dark); border-radius: var(--radius); padding: 14px; max-height: 640px; overflow-y: auto; }
#pdf-viewer canvas { display: block; margin: 0 auto 14px; max-width: 100%; height: auto; box-shadow: 0 2px 10px rgba(0,0,0,0.18); background: #fff; }

.sig-wrap { border: 2px dashed var(--tan-dark); border-radius: 8px; background: #fffdf9; position: relative; }
.sig-wrap canvas { width: 100%; height: 180px; display: block; touch-action: none; }
.sig-hint { position: absolute; inset: 0; display: flex; align-items: center; justify-content: center; color: var(--tan-dark); font-family: 'Cormorant Garamond', Georgia, serif; font-size: 1.5rem; pointer-events: none; }

.agree-row { display: flex; gap: 10px; align-items: flex-start; margin: 18px 0; }
.agree-row input { width: 18px; height: 18px; margin-top: 2px; flex-shrink: 0; }
.agree-row span { font-size: 0.9rem; color: var(--ink-soft); }

.gold-rule { border: none; border-top: 2px solid var(--gold-light); width: 64px; margin: 10px auto 0; }

/* ---------- misc ---------- */
.muted { color: var(--ink-soft); font-size: 0.85rem; }
.mono { font-family: ui-monospace, Consolas, monospace; font-size: 0.82rem; word-break: break-all; }
.row { display: flex; gap: 10px; flex-wrap: wrap; align-items: center; }
.spread { justify-content: space-between; }
.center { text-align: center; }
.mt { margin-top: 18px; }
.link-box { background: #fdfbf6; border: 1px solid var(--tan); border-radius: 6px; padding: 12px 14px; }
footer.disclaimer { text-align: center; padding: 26px 20px; color: var(--ink-soft); font-size: 0.75rem; max-width: 720px; margin: 0 auto; }
