:root{--text:#6b6375;--text-h:#08060d;--bg:#fff;--border:#e5e4e7;--code-bg:#f4f3ec;--accent:#aa3bff;--accent-bg:#aa3bff1a;--accent-border:#aa3bff80;--social-bg:#f4f3ec80;--shadow:#0000001a 0 10px 15px -3px, #0000000d 0 4px 6px -2px;--sans:system-ui, "Segoe UI", Roboto, sans-serif;--heading:system-ui, "Segoe UI", Roboto, sans-serif;--mono:ui-monospace, Consolas, monospace;font:18px/145% var(--sans);letter-spacing:.18px;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light dark;color:var(--text);background:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}@media (prefers-color-scheme:dark){:root{--lightningcss-light: ;--lightningcss-dark:initial}}@media (width<=1024px){:root{font-size:16px}}@media (prefers-color-scheme:dark){:root{--text:#9ca3af;--text-h:#f3f4f6;--bg:#16171d;--border:#2e303a;--code-bg:#1f2028;--accent:#c084fc;--accent-bg:#c084fc26;--accent-border:#c084fc80;--social-bg:#2f303a80;--shadow:#0006 0 10px 15px -3px, #00000040 0 4px 6px -2px}#social .button-icon{filter:invert()brightness(2)}}#root{text-align:center;border-inline:1px solid var(--border);box-sizing:border-box;flex-direction:column;width:1280px;max-width:100%;min-height:100svh;margin:0 auto;display:flex}body{margin:0}h1,h2{font-family:var(--heading);color:var(--text-h);font-weight:500}h1{letter-spacing:-1.68px;margin:32px 0;font-size:56px}@media (width<=1024px){h1{margin:20px 0;font-size:36px}}h2{letter-spacing:-.24px;margin:0 0 8px;font-size:24px;line-height:118%}@media (width<=1024px){h2{font-size:20px}}p{margin:0}code,.counter{font-family:var(--mono);color:var(--text-h);border-radius:4px;display:inline-flex}code{background:var(--code-bg);padding:4px 8px;font-size:15px;line-height:135%}*{box-sizing:border-box}body{background-color:#f8fafc;justify-content:center;margin:0;padding:20px;display:flex}.calendar-container{background:#fff;border:1px solid #e2e8f0;border-radius:12px;width:100%;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;overflow:hidden;box-shadow:0 10px 25px #0000000d}.calendar-header{color:#0f172a;background-color:#fff;border-bottom:1px solid #e2e8f0;justify-content:space-between;align-items:center;padding:20px 24px;display:flex}.calendar-header h2{margin:0;font-size:1.5rem;font-weight:600}.calendar-header button{color:#475569;cursor:pointer;background:#f1f5f9;border:none;border-radius:6px;padding:8px 16px;font-size:14px;transition:background .2s}.calendar-header button:hover{background:#e2e8f0}.weekdays-grid{text-align:center;color:#64748b;background-color:#f8fafc;border-bottom:1px solid #e2e8f0;grid-template-columns:repeat(7,1fr);padding:12px 0;font-size:.875rem;font-weight:600;display:grid}.days-grid{grid-template-columns:repeat(7,1fr);display:grid}.day-cell,.empty-cell{border-bottom:1px solid #f1f5f9;border-right:1px solid #f1f5f9;flex-direction:column;justify-content:flex-start;min-height:100px;padding:12px;transition:background .1s;display:flex}.day-cell:hover{background-color:#f8fafc}.day-cell:nth-child(7n){border-right:none}.weekend{background-color:#fcfcfc}.gregorian-date{color:#1e293b;margin-bottom:4px;font-size:1.125rem;font-weight:500}.lunar-date{text-align:left;font-size:.75rem}.header-title{text-align:center}.header-title h2{transition:color .2s}.header-title h2:hover{color:#3b82f6}.header-ganzhi{color:#64748b;letter-spacing:2px;margin-top:4px;font-size:.9rem;font-weight:500}.date-header{justify-content:space-between;align-items:flex-start;margin-bottom:6px;display:flex}.ganzhi-group{flex-direction:column;align-items:flex-end;line-height:1.2;display:flex}.ganzhi-text{color:#94a3b8;font-size:.65rem;font-weight:600}.today .ganzhi-text{color:#60a5fa}.today{background-color:#eff6ff;box-shadow:inset 0 0 0 2px #3b82f6}.today .gregorian-date{color:#2563eb;font-weight:700}.today .daily-ganzhi{color:#60a5fa}.app-wrapper{flex-direction:column;align-items:center;width:100%;max-width:100%;display:flex}.controls-bar{justify-content:flex-end;align-items:center;width:100%;padding:0 10px 15px;display:flex}.toggle-label{color:#475569;margin-left:10px;font-size:.875rem;font-weight:500}.toggle-switch{width:40px;height:20px;display:inline-block;position:relative}.toggle-switch input{opacity:0;width:0;height:0}.slider{cursor:pointer;background-color:#cbd5e1;border-radius:20px;transition:all .4s;position:absolute;inset:0}.slider:before{content:"";background-color:#fff;border-radius:50%;width:14px;height:14px;transition:all .4s;position:absolute;bottom:3px;left:3px}input:checked+.slider{background-color:#8b5cf6}input:checked+.slider:before{transform:translate(20px)}.day-cell{position:relative}.hv-tag{color:#b91c1c;background-color:#fef2f2;border:1px solid #fee2e2;border-radius:3px;padding:2px 4px;font-size:.7rem;font-weight:700;line-height:1;position:absolute;bottom:8px;right:8px}.today .hv-tag{color:#2563eb;background-color:#fff;border-color:#3b82f6}.day-cell{border-bottom:1px solid #f1f5f9;border-right:1px solid #f1f5f9;flex-direction:column;min-height:110px;padding:10px;transition:background .1s;display:flex}.date-footer{justify-content:space-between;align-items:flex-end;margin-top:auto;display:flex}.officer-tag{color:#854d0e;background-color:#fef08a;border:1px solid #fde047;border-radius:4px;padding:3px 6px;font-size:.75rem;font-weight:700;line-height:1}.today .officer-tag{color:#1e40af;background-color:#dbeafe;border-color:#bfdbfe}
