@import"https://fonts.googleapis.com/css2?family=Cairo:wght@400;600;700&display=swap";:root{--color-bg: #f5f7fb;--color-surface: #ffffff;--color-surface-2: #f8fafc;--color-text: #0f172a;--color-text-muted: #64748b;--color-border: #e2e8f0;--color-primary: #2563eb;--color-primary-hover: #1d4ed8;--color-primary-contrast: #ffffff;--color-sidebar: #0f172a;--color-sidebar-accent: #1d2b53;--color-sidebar-text: rgba(255, 255, 255, .8);--color-badge-bg: #e0e7ff;--color-badge-text: #312e81;--color-login-gradient-start: #f0f4f8;--color-login-gradient-end: #d9e2ec;--color-error-bg: #fde8e8;--color-error-text: #b83232;--color-offline-bg: #3f2c00;--color-offline-text: #fcd34d;--color-offline-border: rgba(252, 211, 77, .2);--color-accent: #22d3ee;--color-accent-strong: #06b6d4;--color-danger: #f87171;--color-warning: #fbbf24;--color-success: #34d399;--color-button-text-on-accent: #04101f;--shadow-card: 0 10px 30px rgba(15, 23, 42, .08);--shadow-elevated: 0 20px 40px rgba(15, 23, 42, .12)}[data-theme=dark]{--color-bg: #0b1220;--color-surface: #111827;--color-surface-2: #1f2937;--color-text: #e5e7eb;--color-text-muted: #9ca3af;--color-border: #1f2937;--color-primary: #38bdf8;--color-primary-hover: #0ea5e9;--color-primary-contrast: #ffffff;--color-sidebar: #0f172a;--color-sidebar-accent: #1f2a44;--color-sidebar-text: rgba(255, 255, 255, .85);--color-badge-bg: #1e293b;--color-badge-text: #c7d2fe;--color-login-gradient-start: #0b1220;--color-login-gradient-end: #111827;--color-error-bg: #3b0f0f;--color-error-text: #fca5a5;--color-offline-bg: #3f2c00;--color-offline-text: #fcd34d;--color-offline-border: rgba(252, 211, 77, .25);--color-accent: #22d3ee;--color-accent-strong: #06b6d4;--color-danger: #f87171;--color-warning: #fbbf24;--color-success: #34d399;--color-button-text-on-accent: #04101f;--shadow-card: 0 12px 34px rgba(0, 0, 0, .35);--shadow-elevated: 0 24px 48px rgba(0, 0, 0, .4);color-scheme:dark}[data-theme=light]{color-scheme:light}:root{color-scheme:dark;--bg: var(--color-bg);--bg-soft: var(--color-sidebar);--surface: var(--color-surface);--surface-2: var(--color-surface-2);--text: var(--color-text);--muted: var(--color-text-muted);--accent: var(--color-accent);--accent-strong: var(--color-accent-strong);--danger: var(--color-danger);--warning: var(--color-warning);--success: var(--color-success);--border: var(--color-border);font-family:Cairo,Segoe UI,Tahoma,sans-serif;background:var(--bg);color:var(--text)}*,*:before,*:after{box-sizing:border-box}body{margin:0;min-height:100vh;background:var(--bg);color:var(--text)}a{color:inherit;text-decoration:none}button{border:none;border-radius:12px;background:linear-gradient(135deg,var(--accent),var(--accent-strong));color:var(--color-button-text-on-accent);font-weight:700;padding:12px 16px;cursor:pointer;width:100%;transition:transform .15s ease,box-shadow .15s ease}button:disabled{opacity:.5;cursor:not-allowed;transform:none;box-shadow:none}button:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 8px 24px #22d3ee40}input,select,textarea{width:100%;padding:12px;border-radius:12px;border:1px solid var(--border);background:var(--surface);color:var(--text);font-family:inherit}label{font-size:14px;color:var(--muted);display:block;margin-bottom:6px}.app-shell{max-width:520px;margin:0 auto;padding:16px 16px 72px}.page{display:flex;flex-direction:column;gap:12px}.card{background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:16px;box-shadow:0 10px 30px #0003}.card-header{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:8px;font-weight:700}.pill{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;border-radius:999px;background:var(--surface-2);color:var(--muted);font-size:12px}.list{display:flex;flex-direction:column;gap:8px}.list-item{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:12px;display:flex;justify-content:space-between;gap:8px}.status-dot{display:inline-block;width:10px;height:10px;border-radius:999px}.status-dot.planned{background:var(--warning)}.status-dot.active{background:var(--accent)}.status-dot.done{background:var(--success)}.status-dot.skipped{background:var(--danger)}.offline-banner{position:sticky;top:0;z-index:20;background:var(--color-offline-bg);color:var(--color-offline-text);padding:10px 12px;border-radius:12px;margin-bottom:10px;border:1px solid var(--color-offline-border)}.section-title{font-size:18px;font-weight:700;margin:4px 0}.muted{color:var(--muted);font-size:13px}.grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:10px}.bottom-nav{position:fixed;bottom:0;left:0;right:0;background:var(--surface);border-top:1px solid var(--border);display:grid;grid-template-columns:repeat(5,1fr);padding:8px;z-index:50}.bottom-nav a{color:var(--muted);display:flex;flex-direction:column;align-items:center;gap:4px;text-align:center;font-size:12px;padding:8px 4px;border-radius:12px;transition:background .15s ease,color .15s ease}.bottom-nav a.active{color:var(--text);background:var(--surface-2)}.bottom-nav a:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}.bottom-nav__icon{width:20px;height:20px;display:inline-flex;align-items:center;justify-content:center}.bottom-nav__icon svg{width:20px;height:20px;fill:currentColor}.map-container{height:260px;border-radius:16px;overflow:hidden;border:1px solid var(--border)}form{display:flex;flex-direction:column;gap:10px}
