@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&display=swap');

:root {
 --bg: #07101d;
 --bg-glow: rgba(47, 125, 244, 0.18);
 --surface: #0b1324;
 --surface-raised: #101a2f;
 --surface-soft: #13213b;
 --surface-strong: #172742;
 --border: rgba(255, 255, 255, 0.1);
 --border-strong: rgba(255, 255, 255, 0.18);
 --text: #f8fbff;
 --text-soft: #d9e3f4;
 --muted: #9fb0ca;
 --muted-strong: #7384a0;
 --accent: #2f7df4;
 --accent-strong: #1f67d8;
 --accent-soft: rgba(47, 125, 244, 0.12);
 --success: #86efac;
 --success-bg: rgba(34, 197, 94, 0.16);
 --warning: #fdba74;
 --warning-bg: rgba(249, 115, 22, 0.16);
 --danger: #fca5a5;
 --danger-bg: rgba(239, 68, 68, 0.16);
 --notable: #fcd34d;
 --notable-bg: rgba(245, 158, 11, 0.18);
 --shadow-lg: 0 28px 80px rgba(0, 0, 0, 0.34);
 --shadow-md: 0 18px 48px rgba(0, 0, 0, 0.26);
 --radius-xl: 28px;
 --radius-lg: 22px;
 --radius-md: 16px;
 --radius-sm: 12px;
 --font-sans: "Inter", ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
 --font-mono: "JetBrains Mono", "Cascadia Code", "SFMono-Regular", Consolas, monospace;
}

*, *::before, *::after { box-sizing: border-box; }
html { font-size: 16px; }
body {
 margin: 0;
 min-height: 100vh;
 color: var(--text);
 font-family: var(--font-sans);
 line-height: 1.55;
 background:
  radial-gradient(circle at top, var(--bg-glow), transparent 36%),
  linear-gradient(180deg, #07101d 0%, #081120 100%);
}
img { max-width: 100%; display: block; }
a {
 color: var(--text-soft);
 text-decoration: none;
 transition: color 0.18s ease, border-color 0.18s ease, background-color 0.18s ease, opacity 0.18s ease;
}
a:hover { color: var(--text); }
button, input, select, textarea {
 font: inherit;
}

.page {
 width: min(1120px, calc(100% - 32px));
 margin: 0 auto;
}

.topbar-shell {
 position: sticky;
 top: 0;
 z-index: 20;
 background: rgba(7, 16, 29, 0.88);
 backdrop-filter: blur(14px);
 border-bottom: 1px solid var(--border);
}
.topbar {
 display: flex;
 align-items: center;
 justify-content: space-between;
 gap: 20px;
 min-height: 84px;
}
.topbar-brand {
 display: inline-flex;
 align-items: center;
 justify-content: center;
 width: 40px;
 height: 40px;
 min-width: 40px;
 min-height: 40px;
 padding: 0;
 border-radius: 12px;
 background: transparent;
 box-shadow: none;
 flex: 0 0 auto;
}
.topbar-brand:hover {
 opacity: 0.96;
}
.topbar-brand img {
 width: 28px;
 height: 28px;
 max-width: 28px;
 max-height: 28px;
 object-fit: contain;
}
.topbar-nav {
 display: flex;
 align-items: center;
 gap: 12px;
 color: var(--muted);
 font-size: 0.95rem;
}
.topbar-user {
 color: var(--muted);
 font-weight: 500;
}
.topbar-link {
 display: inline-flex;
 align-items: center;
 justify-content: center;
 min-height: 42px;
 padding: 0 16px;
 border-radius: 999px;
 border: 1px solid var(--border);
 background: rgba(255, 255, 255, 0.04);
 color: var(--text-soft);
}
.topbar-link:hover {
 border-color: var(--border-strong);
 background: rgba(255, 255, 255, 0.06);
}

.content-shell {
 padding: 36px 0 56px;
}

.summary-strip,
.state-card,
.card,
.form-card,
.login-card,
.account-panel,
.account-sidebar {
 background: rgba(11, 19, 36, 0.9);
 border: 1px solid var(--border);
 box-shadow: var(--shadow-md);
}

.summary-strip {
 display: flex;
 flex-wrap: wrap;
 gap: 18px 28px;
 margin-bottom: 28px;
 padding: 18px 22px;
 border-radius: var(--radius-lg);
 color: var(--muted);
}
.summary-strip strong {
 color: var(--text);
 font-weight: 700;
}

.section-title {
 margin: 0 0 16px;
 color: var(--muted);
 font-size: 0.78rem;
 font-weight: 700;
 letter-spacing: 0.18em;
 text-transform: uppercase;
}

.page-header {
 display: flex;
 justify-content: space-between;
 align-items: flex-start;
 gap: 20px;
 margin-bottom: 28px;
}
.page-header-main {
 display: grid;
 gap: 8px;
}
.page-title {
 margin: 0;
 font-size: clamp(2rem, 5vw, 3rem);
 line-height: 1.02;
 letter-spacing: -0.04em;
}
.page-subtitle {
 color: var(--muted);
 font-size: 1rem;
}
.page-actions {
 display: flex;
 flex-wrap: wrap;
 justify-content: flex-end;
 gap: 12px;
}
.watch-detail-actions {
 width: 100%;
 margin-left: auto;
 display: flex;
 justify-content: space-between;
 align-items: center;
 flex-wrap: nowrap;
 gap: 16px;
}
.watch-detail-remove-form {
 margin-left: auto;
}
.watch-detail-remove-button {
 color: #f87171 !important;
 border-color: rgba(248, 113, 113, 0.34) !important;
 background: rgba(239, 68, 68, 0.05);
 font-weight: 700;
}
.watch-detail-remove-button:hover {
 color: #fecaca !important;
 background: rgba(239, 68, 68, 0.08);
 border-color: rgba(239, 68, 68, 0.36);
}

.stack-sm > * + * { margin-top: 12px; }
.stack-md > * + * { margin-top: 18px; }
.stack-lg > * + * { margin-top: 26px; }

.card,
.form-card,
.account-panel {
 border-radius: var(--radius-lg);
 padding: 24px;
}
.form-card {
 max-width: 620px;
}
.card:hover {
 border-color: var(--border-strong);
}

.watch-card-header {
 display: flex;
 justify-content: space-between;
 align-items: flex-start;
 gap: 16px;
 margin-bottom: 8px;
}
.watch-card-label {
 color: var(--text);
 font-size: 1.1rem;
 font-weight: 700;
 line-height: 1.2;
}
.watch-card-label a {
 color: inherit;
}
.watch-card-meta {
 color: var(--muted);
 font-size: 0.92rem;
}
.watch-card-footer {
 display: flex;
 flex-wrap: wrap;
 align-items: center;
 gap: 10px;
 margin-top: 18px;
 color: var(--muted);
 font-size: 0.9rem;
}

.mono {
 font-family: var(--font-mono);
}
.muted { color: var(--muted); }
.muted-2 { color: var(--muted-strong); }

.badge {
 display: inline-flex;
 align-items: center;
 justify-content: center;
 min-height: 28px;
 padding: 0 12px;
 border-radius: 999px;
 font-size: 0.72rem;
 font-weight: 700;
 letter-spacing: 0.08em;
 text-transform: uppercase;
 border: 1px solid transparent;
}
.badge-success { background: var(--success-bg); color: var(--success); }
.badge-warning { background: var(--warning-bg); color: var(--warning); }
.badge-danger { background: var(--danger-bg); color: var(--danger); }
.badge-notable { background: var(--notable-bg); color: var(--notable); }
.badge-neutral {
 background: rgba(255, 255, 255, 0.06);
 border-color: rgba(255, 255, 255, 0.08);
 color: var(--text-soft);
}
.badge-accent { background: var(--accent-soft); color: #9ec5ff; }

.divider {
 margin: 34px 0;
 border: 0;
 border-top: 1px solid var(--border);
}

.state-card {
 border-radius: var(--radius-lg);
 padding: 22px 24px;
}
.state-card-title {
 margin-bottom: 14px;
 color: var(--muted);
 font-size: 0.78rem;
 font-weight: 700;
 letter-spacing: 0.18em;
 text-transform: uppercase;
}
.state-grid {
 display: grid;
 grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
 gap: 14px 18px;
}
.state-item label {
 display: block;
 margin-bottom: 6px;
 color: var(--muted);
 font-size: 0.74rem;
 font-weight: 700;
 letter-spacing: 0.12em;
 text-transform: uppercase;
}
.state-item span {
 color: var(--text);
 font-size: 0.98rem;
}

.timeline {
 display: grid;
 gap: 12px;
}
.event-row {
 display: grid;
 grid-template-columns: 150px 180px minmax(0, 1fr) 36px;
 gap: 16px;
 align-items: start;
 padding: 18px 20px;
 border-radius: var(--radius-md);
 border: 1px solid var(--border);
 background: rgba(11, 19, 36, 0.78);
}
.event-row.notable-row {
 background: rgba(245, 158, 11, 0.08);
 border-color: rgba(245, 158, 11, 0.24);
}
.event-time,
.event-field {
 color: var(--muted);
 font-size: 0.86rem;
}
.event-time,
.event-field,
.state-item span,
.watch-card-meta .mono,
.topbar-user .mono {
 font-family: var(--font-mono);
}
.event-change {
 color: var(--text);
}
.event-star {
 color: var(--notable);
 font-size: 1rem;
 text-align: right;
}

.permits-table {
 width: 100%;
 border-collapse: collapse;
}
.permits-table th,
.permits-table td {
 padding: 14px 14px 14px 0;
 border-bottom: 1px solid var(--border);
 text-align: left;
}
.permits-table th {
 color: var(--muted);
 font-size: 0.78rem;
 font-weight: 700;
 letter-spacing: 0.12em;
 text-transform: uppercase;
}
.permits-table td {
 color: var(--text);
 font-size: 0.95rem;
}

.form-group { margin-bottom: 18px; }
.form-group label {
 display: block;
 margin-bottom: 8px;
 color: var(--muted);
 font-size: 0.76rem;
 font-weight: 700;
 letter-spacing: 0.12em;
 text-transform: uppercase;
}
input[type="text"],
input[type="email"],
input[type="tel"],
input[type="password"],
select,
textarea {
 width: 100%;
 min-height: 52px;
 padding: 14px 16px;
 color: var(--text);
 background: rgba(255, 255, 255, 0.04);
 border: 1px solid var(--border);
 border-radius: var(--radius-sm);
 outline: none;
 transition: border-color 0.18s ease, background-color 0.18s ease, box-shadow 0.18s ease;
}
input::placeholder,
textarea::placeholder {
 color: var(--muted-strong);
}
input:focus,
select:focus,
textarea:focus {
 border-color: rgba(90, 161, 255, 0.5);
 background: rgba(255, 255, 255, 0.06);
 box-shadow: 0 0 0 4px rgba(47, 125, 244, 0.12);
}
select {
 appearance: none;
 background-image:
  linear-gradient(45deg, transparent 50%, #9fb0ca 50%),
  linear-gradient(135deg, #9fb0ca 50%, transparent 50%);
 background-position:
  calc(100% - 20px) calc(50% - 3px),
  calc(100% - 14px) calc(50% - 3px);
 background-size: 6px 6px, 6px 6px;
 background-repeat: no-repeat;
 padding-right: 44px;
}

.btn {
 display: inline-flex;
 align-items: center;
 justify-content: center;
 min-height: 46px;
 padding: 0 18px;
 border-radius: 14px;
 border: 1px solid transparent;
 font-size: 0.92rem;
 font-weight: 700;
 cursor: pointer;
 transition: transform 0.18s ease, border-color 0.18s ease, background-color 0.18s ease, opacity 0.18s ease;
}
.btn:hover {
 transform: translateY(-1px);
 text-decoration: none;
}
.btn-primary {
 background: var(--accent);
 color: white;
 box-shadow: 0 18px 50px rgba(47, 125, 244, 0.24);
}
.btn-primary:hover { background: #4189f7; }
.btn-secondary {
 background: rgba(255, 255, 255, 0.08);
 border-color: var(--border);
 color: var(--text);
}
.btn-secondary:hover {
 border-color: var(--border-strong);
 background: rgba(255, 255, 255, 0.1);
}
.btn-ghost {
 background: transparent;
 border-color: var(--border);
 color: var(--muted);
}
.btn-ghost:hover {
 border-color: var(--border-strong);
 color: var(--text);
}
.btn-danger {
 background: transparent;
 border-color: rgba(239, 68, 68, 0.28);
 color: var(--danger);
}
.btn-danger:hover {
 background: rgba(239, 68, 68, 0.08);
 border-color: rgba(239, 68, 68, 0.42);
}
.btn-sm {
 min-height: 36px;
 padding: 0 12px;
 font-size: 0.82rem;
 border-radius: 12px;
}

.alert {
 margin-bottom: 18px;
 padding: 14px 16px;
 border-radius: var(--radius-md);
 border: 1px solid transparent;
 font-size: 0.95rem;
}
.alert-error {
 color: var(--danger);
 background: var(--danger-bg);
 border-color: rgba(239, 68, 68, 0.2);
}
.alert-success {
 color: var(--success);
 background: var(--success-bg);
 border-color: rgba(34, 197, 94, 0.2);
}

.empty-state {
 padding: 38px 22px;
 border-radius: var(--radius-lg);
 border: 1px dashed var(--border);
 background: rgba(255, 255, 255, 0.03);
 color: var(--muted);
 text-align: center;
}
.empty-state p + p { margin-top: 8px; }

.login-wrap {
 display: flex;
 align-items: center;
 justify-content: center;
 min-height: 100vh;
 padding: 28px 16px;
}
.login-card {
 width: min(100%, 480px);
 border-radius: var(--radius-xl);
 padding: 28px;
}
.login-brand-wrap {
 display: inline-flex;
 width: fit-content;
 max-width: 280px;
 padding: 12px;
 margin-bottom: 18px;
 border-radius: 20px;
 background: rgba(255, 255, 255, 0.98);
}
.login-brand-image {
 display: block;
 width: min(240px, 100%);
 height: auto;
}
.login-title {
 margin: 0 0 6px;
 font-size: 2rem;
 line-height: 1.05;
 letter-spacing: -0.04em;
}
.login-subtitle {
 margin-bottom: 28px;
 color: var(--muted);
 font-size: 1rem;
}

.back-link {
 display: inline-flex;
 align-items: center;
 gap: 6px;
 margin-bottom: 18px;
 color: var(--muted);
 font-size: 0.92rem;
 font-weight: 600;
}
.back-link:hover { color: var(--text); }

.account-shell {
 display: grid;
 grid-template-columns: 260px minmax(0, 1fr);
 gap: 28px;
 align-items: start;
}
.account-sidebar {
 position: sticky;
 top: 108px;
 border-radius: var(--radius-lg);
 padding: 24px;
}
.account-sidebar-title {
 margin: 0 0 18px;
 font-size: 1.9rem;
 line-height: 1.05;
 letter-spacing: -0.03em;
}
.account-nav {
 display: grid;
 gap: 10px;
}
.account-nav-link {
 display: flex;
 align-items: center;
 min-height: 48px;
 padding: 0 16px;
 border-radius: 14px;
 color: var(--text-soft);
}
.account-nav-link:hover {
 background: rgba(255, 255, 255, 0.06);
}
.account-nav-link.is-active {
 background: rgba(255, 255, 255, 0.08);
 color: var(--text);
}
.account-panel-narrow {
 max-width: 720px;
}
.account-title {
 margin: 0 0 10px;
 font-size: clamp(2rem, 5vw, 2.8rem);
 line-height: 1.02;
 letter-spacing: -0.04em;
}
.account-description {
 margin: 0 0 24px;
 max-width: 720px;
 color: var(--muted);
 font-size: 1rem;
}
.account-actions {
 display: flex;
 flex-wrap: wrap;
 gap: 12px;
 margin-top: 10px;
}

.dashboard-grid {
 display: grid;
 gap: 26px;
 grid-template-columns: minmax(0, 1.45fr) minmax(320px, 0.95fr);
 align-items: start;
}

.tab-nav {
 display: flex;
 flex-wrap: wrap;
 gap: 12px;
 margin-bottom: 22px;
 padding-bottom: 4px;
 border-bottom: 1px solid var(--border);
}
.tab-button {
 display: inline-flex;
 align-items: center;
 gap: 6px;
 min-height: 42px;
 padding: 0 14px;
 border: 1px solid transparent;
 border-radius: 999px;
 background: transparent;
 color: var(--muted);
 cursor: pointer;
}
.tab-button:hover {
 color: var(--text);
 background: rgba(255, 255, 255, 0.05);
}
.tab-button.is-active {
 background: var(--accent-soft);
 border-color: rgba(90, 161, 255, 0.18);
 color: var(--text);
}

.detail-meta {
 color: var(--muted);
 font-size: 0.96rem;
}
.detail-section {
 margin-top: 34px;
}

.property-layout {
 display: grid;
 grid-template-columns: minmax(0, 1.45fr) minmax(280px, 0.65fr);
 gap: 24px;
 align-items: start;
}
.property-map-card,
.watch-cta-card {
 display: grid;
 gap: 16px;
}
.property-map-header {
 display: flex;
 justify-content: space-between;
 gap: 16px;
 align-items: flex-start;
}
.property-map-header .section-title {
 margin-bottom: 4px;
}
.property-map {
 width: 100%;
 min-height: 360px;
 border-radius: var(--radius-md);
 overflow: hidden;
 border: 1px solid var(--border);
 background: rgba(255, 255, 255, 0.04);
}
.map-status,
.map-copy,
.watch-cta-card p {
 margin: 0;
 color: var(--muted);
}
.watch-cta-card h2 {
 margin: 0;
 font-size: 1.5rem;
 line-height: 1.15;
}
.link-button {
 justify-self: start;
 padding: 0;
 border: 0;
 background: transparent;
 color: #9ec5ff;
 cursor: pointer;
 font-weight: 700;
}
.link-button:hover {
 color: var(--text);
}
.feedback-form {
 display: grid;
 gap: 12px;
 padding-top: 4px;
}
.profile-grid {
 display: grid;
 grid-template-columns: repeat(2, minmax(0, 1fr));
 gap: 18px;
}
.profile-panel {
 display: grid;
 align-content: start;
 gap: 12px;
}
.profile-panel-header {
 display: flex;
 align-items: center;
 justify-content: space-between;
 gap: 12px;
}
.profile-panel-header h2 {
 margin: 0;
 font-size: 1.05rem;
 line-height: 1.25;
}
.profile-record {
 display: grid;
 gap: 4px;
 padding: 12px 0;
 border-top: 1px solid var(--border);
}
.profile-record:first-of-type {
 border-top: 0;
 padding-top: 0;
}
.profile-record span,
.profile-record small {
 color: var(--muted);
}
.universal-search-form {
 display: grid;
 gap: 14px;
}
.universal-search-suggestions {
 overflow: hidden;
 border: 1px solid var(--border);
 border-radius: var(--radius-md);
 background: rgba(255, 255, 255, 0.04);
}
.universal-search-suggestion {
 display: block;
 width: 100%;
 padding: 12px 14px;
 border: 0;
 border-bottom: 1px solid var(--border);
 background: transparent;
 color: var(--text);
 text-align: left;
 cursor: pointer;
}
.universal-search-suggestion:last-child {
 border-bottom: 0;
}
.universal-search-suggestion:hover {
 background: rgba(255, 255, 255, 0.06);
}
.universal-search-state {
 padding: 12px 14px;
 border: 1px solid rgba(251, 191, 36, 0.35);
 border-radius: var(--radius-md);
 background: rgba(251, 191, 36, 0.08);
 color: #fde68a;
}

.logo-block {
 display: inline-flex;
 padding: 10px 12px;
 border-radius: 20px;
 background: rgba(255, 255, 255, 0.98);
 box-shadow: var(--shadow-md);
}
.logo-block img {
 height: 52px;
 width: auto;
}

@media (max-width: 960px) {
 .dashboard-grid,
 .account-shell,
 .property-layout,
 .profile-grid {
  grid-template-columns: 1fr;
 }
 .account-sidebar {
  position: static;
 }
}

@media (max-width: 720px) {
 .page {
  width: min(100% - 20px, 1120px);
 }
 .topbar {
  min-height: 76px;
 }
 .topbar-brand {
  width: 36px;
  height: 36px;
  min-width: 36px;
  min-height: 36px;
 }
 .topbar-nav {
  gap: 8px;
  flex-wrap: wrap;
  justify-content: flex-end;
 }
 .summary-strip,
 .card,
 .form-card,
 .account-panel,
 .account-sidebar,
 .login-card,
 .state-card {
  padding: 20px;
 }
 .page-header {
  flex-direction: column;
 }
 .page-actions {
  width: 100%;
  justify-content: flex-start;
 }
 .watch-detail-actions {
  justify-content: space-between;
  align-items: center;
 }
 .event-row {
  grid-template-columns: 1fr;
 }
 .event-star {
  text-align: left;
 }
 .state-grid {
  grid-template-columns: 1fr;
 }
 .account-sidebar-title,
 .account-title,
 .page-title,
 .login-title {
  font-size: 1.8rem;
 }
}
