*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{font-family:Inter,system-ui,-apple-system,Segoe UI,sans-serif;font-size:16px;color:#0f172a;--slate-900: #0f172a;--slate-800: #1e293b;--slate-700: #334155;--slate-600: #475569;--slate-500: #64748b;--slate-400: #94a3b8;--slate-300: #cbd5e1;--slate-200: #e2e8f0;--slate-100: #f1f5f9;--slate-50: #f8fafc;--amber: #f59e0b;--amber-light: #fbbf24}body{height:100vh;display:flex;flex-direction:column;background:var(--slate-50);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{height:100%;display:flex;flex-direction:column}.app{display:flex;flex-direction:column;height:100%}.header{display:flex;align-items:center;justify-content:space-between;gap:1.5rem;padding:.85rem 1.25rem;background:linear-gradient(135deg,var(--slate-900) 0%,var(--slate-800) 100%);border-bottom:1px solid var(--slate-700);box-shadow:0 1px 3px #00000014;flex-shrink:0;flex-wrap:wrap}.brand{display:flex;align-items:center;gap:.7rem}.brand-mark{font-size:1.6rem;line-height:1;color:var(--amber);filter:drop-shadow(0 0 6px rgba(245,158,11,.45))}.brand-text h1{font-size:1.15rem;font-weight:700;letter-spacing:-.01em;color:#fff;line-height:1.1}.brand-tagline{font-size:.78rem;color:var(--slate-400);margin-top:2px;font-weight:400}.datetime-picker{display:flex;align-items:center;gap:.5rem}.datetime-label{font-size:.72rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--slate-400)}input[type=datetime-local]{border:1px solid var(--slate-700);background:var(--slate-800);color:#fff;border-radius:6px;padding:.4rem .6rem;font-size:.85rem;font-family:inherit;outline:none;transition:border-color .15s,box-shadow .15s;color-scheme:dark}input[type=datetime-local]:focus{border-color:var(--amber);box-shadow:0 0 0 3px #f59e0b2e}.instructions{display:flex;align-items:center;justify-content:center;gap:.75rem;flex-wrap:wrap;padding:.6rem 1rem;background:#fff;border-bottom:1px solid var(--slate-200);font-size:.82rem;color:var(--slate-700);flex-shrink:0}.instructions>span{display:inline-flex;align-items:center;gap:.4rem}.instructions-divider{color:var(--slate-300)}.step{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:50%;background:var(--amber);color:#fff;font-size:.7rem;font-weight:700;line-height:1}.map-container{flex:1;min-height:0}.map-message{height:100%;display:flex;align-items:center;justify-content:center;color:var(--slate-400);font-size:.9rem;background:var(--slate-50)}.locate-btn{position:absolute;top:12px;left:12px;width:38px;height:38px;border-radius:50%;background:#fff;border:1px solid var(--slate-200);box-shadow:0 2px 8px #0f172a26;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--slate-700);z-index:5;transition:background .15s,color .15s,transform .15s;padding:0}.locate-btn:hover{background:var(--slate-50);color:var(--amber);transform:scale(1.05)}.locate-btn:active{transform:scale(.95)}.sun-compass{background:#fffffff5;border:1px solid var(--slate-200);border-radius:10px;padding:7px 9px;box-shadow:0 4px 14px #0f172a1f,0 1px 3px #0f172a0f;display:flex;flex-direction:column;align-items:center;gap:4px;min-width:76px;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.sun-compass--corner{position:absolute;top:12px;right:12px;z-index:5}.sun-compass--attached{pointer-events:auto}.compass-ring{position:relative;width:64px;height:64px;border:1.5px solid var(--slate-200);border-radius:50%;background:radial-gradient(circle,#fff 60%,var(--slate-50) 100%)}.cn,.cs,.ce,.cw{position:absolute;font-size:.6rem;font-weight:700;color:var(--slate-500);letter-spacing:.05em;line-height:1}.cn{top:2px;left:50%;transform:translate(-50%)}.cs{bottom:2px;left:50%;transform:translate(-50%)}.ce{right:3px;top:50%;transform:translateY(-50%)}.cw{left:3px;top:50%;transform:translateY(-50%)}.sun-needle{position:absolute;bottom:50%;left:50%;width:10px;height:44%;margin-left:-5px;transform-origin:bottom center;background:linear-gradient(to top,#f59e0b,#fbbf24);clip-path:polygon(50% 0%,100% 100%,50% 85%,0% 100%)}.needle-sun{position:absolute;top:-11px;left:50%;transform:translate(-50%);font-size:12px;font-style:normal;filter:drop-shadow(0 0 2px rgba(245,158,11,.5))}.needle-moon{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:20px}.compass-label{font-size:.65rem;color:var(--slate-600);white-space:nowrap;text-align:center;font-variant-numeric:tabular-nums}.compass-hour{font-weight:700;color:var(--amber)}.status-loading{color:var(--slate-400);font-style:italic;font-size:.85rem}.status-error{color:#c0392b;font-size:.85rem}
