:root{--bg: #f5f5f7;--bg-card: #ffffff;--fg: #111827;--fg-muted: #4b5563;--accent: #2563eb;--accent-soft: #dbeafe;--border: #e5e7eb;--danger: #b91c1c}:root[data-theme=dark]{--bg: #020617;--bg-card: #020617;--fg: #e5e7eb;--fg-muted: #9ca3af;--accent: #60a5fa;--accent-soft: #1d283a;--border: #1f2937;--danger: #fca5a5}*,*:before,*:after{box-sizing:border-box}body{margin:0;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:var(--bg);color:var(--fg)}.app{max-width:960px;margin:0 auto;padding:1.5rem 1rem 3rem}.app-header{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1.5rem}.app-header h1{margin:0;font-size:1.5rem}.runedate{margin:.25rem 0 0;color:var(--fg-muted);font-size:.9rem}.theme-toggle{border-radius:999px;border:1px solid var(--border);background:var(--bg-card);color:var(--fg);padding:.4rem .9rem;cursor:pointer;font-size:.85rem}.theme-toggle:hover{border-color:var(--accent)}.runedate-notice{border-radius:.75rem;border:1px solid var(--accent);background:var(--accent-soft);color:var(--fg);padding:.75rem 1rem;display:flex;align-items:center;justify-content:space-between;gap:.75rem;margin-bottom:1rem;font-size:.9rem}.runedate-actions button{margin-left:.5rem;padding:.3rem .7rem;border-radius:999px;border:1px solid var(--border);background:var(--bg-card);color:var(--fg);cursor:pointer;font-size:.8rem}.runedate-actions button:first-of-type{border-color:var(--accent)}.status{margin:.5rem 0 1rem;font-size:.9rem;color:var(--fg-muted)}.status.error{color:var(--danger)}.locations-list{display:flex;flex-direction:column;gap:1rem}.location-card{border-radius:.75rem;border:1px solid var(--border);background:var(--bg-card);padding:.9rem 1rem;box-shadow:0 1px 2px #0f172a0d}.location-header{display:flex;align-items:center;justify-content:space-between;gap:.75rem;margin-bottom:.5rem}.location-header h2{margin:0;font-size:1.05rem}.badge{font-size:.75rem;padding:.15rem .5rem;border-radius:999px;border:1px solid var(--border);color:var(--fg-muted)}.location-body{font-size:.9rem;margin-bottom:.75rem}.location-text{margin:0 0 .25rem}.location-confined{margin:0 0 .25rem;color:var(--fg-muted)}.location-meta{margin:.25rem 0 0;display:flex;flex-wrap:wrap;gap:.75rem;font-size:.8rem;color:var(--fg-muted)}.location-actions{border-top:1px solid var(--border);padding-top:.75rem;display:flex;flex-direction:column;gap:.5rem}.location-input{width:100%;padding:.4rem .6rem;border-radius:.5rem;border:1px solid var(--border);background:var(--bg);color:var(--fg);font-size:.9rem}.location-input:focus{outline:2px solid var(--accent);outline-offset:1px}.buttons-row{display:flex;flex-wrap:wrap;gap:.5rem}.buttons-row button{padding:.35rem .8rem;border-radius:999px;border:1px solid var(--border);background:var(--bg-card);color:var(--fg);font-size:.85rem;cursor:pointer}.buttons-row button:first-of-type{border-color:var(--accent)}.buttons-row button:disabled{opacity:.5;cursor:not-allowed}.updates-disabled{margin:0;font-size:.85rem;color:var(--fg-muted);font-style:italic}@media(max-width:640px){.app{padding-inline:.75rem}.location-header{flex-direction:column;align-items:flex-start}}.refresh-bar-container{width:100%;height:6px;background:var(--border);border-radius:4px;overflow:hidden;margin-bottom:.5rem}.refresh-bar{height:100%;background:var(--accent);transition:width .1s linear}.refresh-label{margin:0 0 1rem;font-size:.8rem;color:var(--fg-muted)}.refresh-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}.refresh-now{padding:.35rem .8rem;border-radius:999px;border:1px solid var(--accent);background:var(--bg-card);color:var(--fg);cursor:pointer;font-size:.85rem}.refresh-now:hover{background:var(--accent-soft)}@keyframes pulse{0%{box-shadow:0 0 #60a5fa66}70%{box-shadow:0 0 0 10px #60a5fa00}to{box-shadow:0 0 #60a5fa00}}.location-card.pulse{animation:pulse .6s ease-out}
