:root {
  --primary: #6366f1;
  --text: #1a1a1a;
  --muted: #888888;
  --background: #fafafa;
  --surface: #ffffff;
  --border: #e5e5e5;
  --error: #dc2626;
  --success: #22c55e;
  --primary-50: #f7f7fe;
  --primary-100: #efeffd;
  --primary-200: #d8d8fb;
  --primary-300: #b1b2f8;
  --primary-400: #8a8cf4;
  --primary-500: #6366f1;
  --primary-600: #595bd8;
  --primary-700: #4a4cb4;
  --space-xs: 4px;
  --space-sm: 8px;
  --space-md: 16px;
  --space-lg: 24px;
  --space-xl: 32px;
  --focus-ring: 0 0 0 3px var(--primary-200);
  --wa-color-primary-600: #6366f1;
  --wa-color-danger-600: #dc2626;
  --wa-color-success-600: #22c55e;
}

wa-cloak { display: none; }

*, *::before, *::after { box-sizing: border-box; }
body { font-family: system-ui, -apple-system, sans-serif; font-size: 16px; line-height: 1.5; margin: 0; padding: 0; color: var(--text); background: var(--background); }
h1, h2, h3 { font-weight: 600; }

header.header { position: sticky; top: 0; z-index: 100; background: var(--surface); border-bottom: 1px solid var(--border); padding: var(--space-sm) var(--space-lg); display: flex !important; align-items: center; justify-content: space-between; width: 100%; }
body.no-header header.header { display: none !important; }
.header-left { display: flex; align-items: center; gap: var(--space-md); flex: 0 0 auto; }
.header-left a { text-decoration: none; color: var(--text); font-weight: 500; font-size: 0.9rem; }
.header-left a:first-child { font-weight: 700; }
.header-left a:hover { color: var(--primary); }
.header-center { flex: 1 1 auto; text-align: center; font-weight: 600; font-size: 1.1rem; }
.header-right { display: flex; align-items: center; gap: var(--space-sm); flex: 0 0 auto; }
.ambient-place { display: inline-flex; align-items: center; gap: 0.35rem; padding: 0.2rem 0.6rem; border-radius: 999px; background: var(--wa-color-neutral-fill-quiet, #f1f5f9); color: var(--text); text-decoration: none; font-size: 0.8rem; font-weight: 500; max-width: 16rem; }
.ambient-place:hover { background: var(--wa-color-neutral-fill-normal, #e2e8f0); }
.ambient-place-icon { color: var(--primary, #2563eb); font-size: 1rem; line-height: 1; }
.ambient-place-name { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }

main.content { width: 70%; max-width: 900px; margin: 0 auto; padding: var(--space-lg) var(--space-md); }
.content-narrow { width: 35%; max-width: 900px; margin: 0 auto; padding: var(--space-lg) var(--space-md); }

wa-input, wa-textarea, wa-select { display: block; width: 100%; }

.reference-field { display: block; width: 100%; margin-block: 0.5rem 0; }
.reference-field > label { display: block; font-size: 0.875rem; font-weight: 500; margin-bottom: 0.25rem; color: var(--text, #0f172a); }
.reference-input { display: block; width: 100%; box-sizing: border-box; padding: 0.5rem 0.75rem; font: inherit; color: var(--text, #0f172a); background: var(--wa-color-neutral-fill-quiet, #fff); border: 1px solid var(--wa-color-neutral-border-normal, #cbd5e1); border-radius: 0.375rem; outline: none; transition: border-color 120ms, box-shadow 120ms; }
.reference-input:focus { border-color: var(--primary, #2563eb); box-shadow: 0 0 0 2px color-mix(in srgb, var(--primary, #2563eb) 25%, transparent); }

.reference-list-field { display: block; width: 100%; margin-block: 0.5rem 0; }
.reference-list-field > label { display: block; font-size: 0.875rem; font-weight: 500; margin-bottom: 0.25rem; color: var(--text, #0f172a); }
.reference-list-chips { display: flex; flex-wrap: wrap; gap: 0.25rem; margin-bottom: 0.25rem; min-height: 0; }
.reference-list-chips:empty { display: none; }
.reference-list-chip { display: inline-flex; align-items: center; gap: 0.25rem; padding: 0.125rem 0.25rem 0.125rem 0.5rem; font-size: 0.875rem; line-height: 1.25; background: var(--wa-color-neutral-fill-quiet, #f1f5f9); border: 1px solid var(--wa-color-neutral-border-normal, #cbd5e1); border-radius: 9999px; color: var(--text, #0f172a); }
.reference-list-chip-remove { appearance: none; background: transparent; border: 0; padding: 0 0.25rem; margin: 0; font: inherit; line-height: 1; cursor: pointer; color: var(--wa-color-neutral-text-quiet, #64748b); }
.reference-list-chip-remove:hover, .reference-list-chip-remove:focus { color: var(--text, #0f172a); outline: none; }
.reference-list-input { display: block; width: 100%; box-sizing: border-box; padding: 0.5rem 0.75rem; font: inherit; color: var(--text, #0f172a); background: var(--wa-color-neutral-fill-quiet, #fff); border: 1px solid var(--wa-color-neutral-border-normal, #cbd5e1); border-radius: 0.375rem; outline: none; transition: border-color 120ms, box-shadow 120ms; }
.reference-list-input:focus { border-color: var(--primary, #2563eb); box-shadow: 0 0 0 2px color-mix(in srgb, var(--primary, #2563eb) 25%, transparent); }

wa-avatar { display: inline-flex; cursor: pointer; }

wa-dialog.dialog-compose { --width: min(32rem, 92vw); }
wa-dialog.dialog-compose.dialog-compose--wide { --width: 80vw; }
wa-dialog.dialog-compose.dialog-compose--medium { --width: min(48rem, 92vw); }
wa-dialog.dialog-form { --width: min(32rem, 92vw); }
wa-dialog.dialog-form.dialog-form--medium { --width: min(48rem, 92vw); }
wa-dialog.dialog-confirm { --width: min(24rem, 92vw); }
wa-dialog.dialog-compose.dialog-compose--wide wa-textarea::part(textarea) { min-height: 70vh; }

div.compose-trigger { cursor: pointer; padding: var(--space-md); border: 1px solid var(--border); border-radius: 8px; background: var(--surface); margin-bottom: var(--space-lg); transition: border-color 0.15s, box-shadow 0.15s; }
div.compose-trigger:hover { border-color: var(--primary); box-shadow: var(--focus-ring); }
.compose-trigger-text { color: var(--muted); }

.save-status { font-size: 0.85rem; line-height: 44px; margin-right: auto; }
.save-status--saving { color: var(--muted); }
.save-status--saved { color: var(--success); }
.save-status--error { color: var(--error); }

.form-group { margin-bottom: var(--space-md); }
.form-group label { display: block; font-weight: 500; margin-bottom: var(--space-xs); font-size: 0.9rem; }
.form-actions { display: flex; justify-content: flex-end; gap: var(--space-sm); padding-top: var(--space-md); }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-md); align-items: start; margin-bottom: var(--space-md); }
.form-row > .form-group { margin-bottom: 0; }
wa-dialog:not([data-edit-id]) [data-edit-only="true"] { display: none; }
wa-dialog:not([data-edit-id]) .form-row:has(> [data-edit-only="true"]) { grid-template-columns: 1fr; }

.list-container { display: flex; flex-direction: column; }
.list-item { display: flex; align-items: center; gap: var(--space-sm); padding: var(--space-sm) var(--space-xs); border-bottom: 1px solid var(--border); }
.list-item:hover { background: var(--background); }
.list-item--clickable { cursor: pointer; }
.list-item .primary-col { flex: 1; min-width: 0; }
.list-item .primary { display: block; color: var(--text); }
.list-item .metadata { display: inline-block; color: var(--muted); font-size: 0.85rem; margin-right: var(--space-sm); }
.list-item .actions { flex-shrink: 0; margin-left: auto; opacity: 0; transition: opacity 0.15s; }
.list-item:hover .actions { opacity: 1; }

.group-header { position: sticky; top: 48px; background: var(--background); padding: var(--space-xs) 0; font-size: 0.85rem; color: var(--muted); font-weight: 600; border-bottom: 1px solid var(--border); }

.search-row { margin-bottom: var(--space-md); }
.search-row wa-input { display: block; width: 100%; }
.list-sentinel { text-align: center; color: var(--muted); padding: var(--space-sm) 0; font-size: 0.85rem; }

.empty-state { display: flex; flex-direction: column; align-items: center; justify-content: center; gap: var(--space-md); text-align: center; padding: var(--space-xl) 0; color: var(--muted); }
.empty-state p { margin: 0; }
.empty-state-icon { --size: 40px; color: var(--muted); opacity: 0.6; }

.dashboard wa-input { display: block; width: 100%; }

.public-landing { display: flex; flex-direction: column; gap: var(--space-xl); padding: var(--space-xl) 0; }
.public-landing .hero { text-align: center; display: flex; flex-direction: column; align-items: center; gap: var(--space-md); }
.public-landing .hero-headline { margin: 0; font-size: 2.25rem; line-height: 1.15; color: var(--text); }
.public-landing .hero-sub { margin: 0; color: var(--muted); max-width: 36rem; font-size: 1.05rem; }
.public-landing .hero-cta { display: inline-block; padding: var(--space-sm) var(--space-lg); border-radius: 8px; background: var(--primary); color: #fff; text-decoration: none; font-weight: 600; }
.public-landing .hero-cta:hover { background: var(--primary-600); }
.public-landing .pricing-title { margin: 0 0 var(--space-md) 0; text-align: center; font-size: 1.25rem; color: var(--text); }
.public-landing .pricing-tiers { display: flex; flex-wrap: wrap; gap: var(--space-md); justify-content: center; }
.public-landing .pricing-tier { border: 1px solid var(--border); border-radius: 8px; padding: var(--space-lg); background: var(--surface); min-width: 16rem; text-align: center; }
.public-landing .pricing-tier-name { margin: 0 0 var(--space-xs) 0; font-size: 1.1rem; color: var(--text); }
.public-landing .pricing-tier-price { font-size: 1.5rem; font-weight: 700; color: var(--primary); margin-bottom: var(--space-sm); }
.public-landing .pricing-tier-features { margin: 0; color: var(--muted); font-size: 0.95rem; }

.quote-day-landing { position: relative; min-height: min(70vh, 44rem); display: flex; flex-direction: column; align-items: center; justify-content: center; gap: var(--space-lg); text-align: center; padding: var(--space-xl) var(--space-md); }
.quote-day-browse { position: absolute; top: var(--space-md); right: var(--space-md); color: var(--muted); font-size: 0.875rem; text-decoration: none; letter-spacing: 0.02em; }
.quote-day-browse:hover { color: var(--text); text-decoration: underline; }
.quote-day-text { margin: 0; max-width: 50rem; color: var(--text); font-size: clamp(2rem, 4.2vw, 3.8rem); line-height: 1.15; font-style: italic; font-weight: 400; letter-spacing: -0.025em; }
.quote-day-author { margin: 0; color: var(--muted); font-size: clamp(1rem, 2vw, 1.35rem); }
.quote-day-empty { margin: 0; color: var(--text); font-size: clamp(2rem, 5vw, 4rem); }

.login-card { max-width: 22rem; margin: var(--space-xl) auto; padding: var(--space-lg); border: 1px solid var(--border); border-radius: 8px; background: var(--surface); display: flex; flex-direction: column; gap: var(--space-md); }
.login-title { margin: 0; font-size: 1.25rem; color: var(--text); }
.login-error { margin: 0; padding: var(--space-sm) var(--space-md); background: var(--error-bg, #fde8e8); color: var(--error, #b91c1c); border-radius: 6px; font-size: 0.9rem; }
.login-form { display: flex; flex-direction: column; gap: var(--space-md); }
.login-form .form-group { display: flex; flex-direction: column; gap: var(--space-xs); margin: 0; }
.login-form input { width: 100%; padding: var(--space-sm); border: 1px solid var(--border); border-radius: 6px; font-size: 1rem; box-sizing: border-box; }
.login-form input:focus { outline: none; border-color: var(--primary); box-shadow: var(--focus-ring); }
.login-submit { padding: var(--space-sm) var(--space-md); background: var(--primary); color: #fff; border: none; border-radius: 6px; font-weight: 600; font-size: 1rem; cursor: pointer; }
.login-submit:hover { background: var(--primary-600); }

@media (max-width: 768px) {
  main.content, .content-narrow { width: 100%; padding: var(--space-md); }
  header.header { padding: var(--space-xs) var(--space-md); }
  wa-dialog.dialog-compose, wa-dialog.dialog-compose.dialog-compose--wide, wa-dialog.dialog-compose.dialog-compose--medium, wa-dialog.dialog-form, wa-dialog.dialog-form.dialog-form--medium, wa-dialog.dialog-form.dialog-form--wide, wa-dialog.dialog-detail { --width: 100%; --height: 100%; }
  wa-dialog.dialog-compose.dialog-compose--wide wa-textarea::part(textarea) { min-height: calc(100vh - 160px); }
  .form-row { grid-template-columns: 1fr; gap: 0; }
  .form-row > .form-group { margin-bottom: var(--space-md); }
}
