@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&family=Outfit:wght@300;400;500;600;700;800&display=swap";:root{--font-sans: "Inter", system-ui, -apple-system, sans-serif;--font-display: "Outfit", var(--font-sans);--radius-sm: 8px;--radius-md: 12px;--radius-lg: 18px;--radius-xl: 24px;--transition-fast: .15s cubic-bezier(.4, 0, .2, 1);--transition-normal: .25s cubic-bezier(.4, 0, .2, 1);--transition-slow: .4s cubic-bezier(.4, 0, .2, 1);--bg-primary: #f8fafc;--bg-secondary: #ffffff;--bg-card: rgba(255, 255, 255, .7);--bg-card-hover: rgba(255, 255, 255, .95);--border-color: rgba(226, 232, 240, .8);--text-primary: #0f172a;--text-secondary: #475569;--text-muted: #64748b;--color-accent: #6366f1;--color-accent-hover: #4f46e5;--color-gold: #b45309;--color-gold-light: #fef3c7;--color-gold-border: #f59e0b;--color-today-bg: rgba(99, 102, 241, .1);--color-today-border: #6366f1;--color-special-lunar: #dc2626;--color-special-lunar-bg: rgba(220, 38, 38, .05);--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -2px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -4px rgba(0, 0, 0, .1);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .1), 0 8px 10px -6px rgba(0, 0, 0, .1);--backdrop-filter: blur(12px);--glow-opacity: .15}[data-theme=dark]{--bg-primary: #090d16;--bg-secondary: #111827;--bg-card: rgba(17, 24, 39, .6);--bg-card-hover: rgba(17, 24, 39, .85);--border-color: rgba(255, 255, 255, .07);--text-primary: #f8fafc;--text-secondary: #94a3b8;--text-muted: #64748b;--color-accent: #818cf8;--color-accent-hover: #6366f1;--color-gold: #fbbf24;--color-gold-light: rgba(251, 191, 36, .15);--color-gold-border: #f59e0b;--color-today-bg: rgba(129, 140, 248, .12);--color-today-border: #818cf8;--color-special-lunar: #f87171;--color-special-lunar-bg: rgba(248, 113, 113, .08);--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .5);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .4), 0 2px 4px -2px rgba(0, 0, 0, .4);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .4), 0 4px 6px -4px rgba(0, 0, 0, .4);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .5), 0 8px 10px -6px rgba(0, 0, 0, .5);--backdrop-filter: blur(16px);--glow-opacity: .35}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes scaleIn{0%{transform:scale(.95);opacity:0}to{transform:scale(1);opacity:1}}@keyframes pulseBorder{0%{box-shadow:0 0 #818cf866}70%{box-shadow:0 0 0 8px #818cf800}to{box-shadow:0 0 #818cf800}}.animate-fade-in{animation:fadeIn var(--transition-normal) forwards}.animate-slide-up{animation:slideUp var(--transition-normal) forwards}.animate-scale-in{animation:scaleIn var(--transition-normal) forwards}.pulse-glow{animation:pulseBorder 2s infinite}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%;width:100%;overflow:hidden}@media (max-width: 899px){html,body,#root{height:auto;min-height:100%;overflow:visible}}body{font-family:var(--font-sans);background-color:var(--bg-primary);color:var(--text-primary);transition:background-color var(--transition-normal),color var(--transition-normal);line-height:1.5;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow-x:hidden;position:relative}body:before,body:after{content:"";position:fixed;width:40vw;height:40vw;border-radius:50%;z-index:-1;pointer-events:none;filter:blur(100px);opacity:var(--glow-opacity);transition:opacity var(--transition-normal)}body:before{top:-10vw;right:-5vw;background:radial-gradient(circle,var(--color-accent) 0%,rgba(99,102,241,0) 70%)}body:after{bottom:-10vw;left:-5vw;background:radial-gradient(circle,var(--color-gold-border) 0%,rgba(245,158,11,0) 70%)}h1,h2,h3,h4,h5,h6{font-family:var(--font-display);font-weight:700;color:var(--text-primary);line-height:1.25}a{color:var(--color-accent);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--color-accent-hover)}button{cursor:pointer;border:none;background:none;font-family:inherit}input,textarea,select{font-family:inherit;font-size:inherit;color:inherit;background:none;border:none}input:focus,select:focus,textarea:focus{outline:none}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-primary)}::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.app-container{max-width:1200px;margin:0 auto;padding:.75rem 1.5rem 1rem;display:flex;flex-direction:column;gap:.75rem;height:100vh;overflow:clip}.app-header{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:.5rem;padding-bottom:.75rem;border-bottom:1px solid var(--border-color);flex-shrink:0}.brand-section{display:flex;align-items:center;gap:.75rem}.brand-icon{color:var(--color-gold);filter:drop-shadow(0 0 8px rgba(245,158,11,.4))}.brand-title{font-size:1.4rem;font-weight:800;background:linear-gradient(135deg,var(--text-primary) 30%,var(--color-gold) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent}.header-actions{display:flex;align-items:center;gap:1rem}.glass-card{background:var(--bg-card);backdrop-filter:var(--backdrop-filter);-webkit-backdrop-filter:var(--backdrop-filter);border:1px solid var(--border-color);border-radius:var(--radius-lg);transition:background-color var(--transition-normal)}.calendar-controls{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;margin-bottom:.25rem}.month-display-group{display:flex;flex-direction:column;align-items:center;gap:.15rem;text-align:center}.lunar-month-name{font-size:1.2rem;font-weight:800;color:var(--text-primary);font-family:var(--font-display)}.can-chi-subtitle{font-size:.75rem;color:var(--color-gold);font-weight:600;text-transform:uppercase;letter-spacing:1px}.solar-range-info{font-size:.7rem;color:var(--text-muted)}.btn-icon{display:flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:var(--radius-md);border:1px solid var(--border-color);background:var(--bg-secondary);color:var(--text-primary);transition:all var(--transition-fast)}.btn-icon:hover{background:var(--border-color);color:var(--color-accent);transform:scale(1.05)}.btn-icon:active{transform:scale(.95)}.btn-primary{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.6rem 1.25rem;font-weight:600;font-family:var(--font-display);background:linear-gradient(135deg,var(--color-accent) 0%,var(--color-accent-hover) 100%);color:#fff;border-radius:var(--radius-md);transition:all var(--transition-fast);flex-shrink:0}.btn-primary:hover{opacity:.9}.btn-primary:active{transform:translateY(0)}.btn-secondary{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.5rem 1rem;font-weight:600;border:1px solid var(--border-color);background:var(--bg-secondary);color:var(--text-primary);border-radius:var(--radius-md);transition:all var(--transition-fast);font-size:.875rem}.btn-secondary:hover{background:var(--border-color)}.main-layout{display:grid;grid-template-columns:1fr;gap:.75rem;flex:1;min-height:0;overflow:clip}@media (min-width: 900px){.main-layout{grid-template-columns:2.5fr 1fr}}@media (max-width: 899px){.app-container{height:auto;min-height:100vh;overflow:visible}.main-layout,.calendar-wrapper,.details-wrapper{overflow:visible}}.calendar-wrapper{padding:.75rem 1rem;overflow:visible;min-height:0;display:flex;flex-direction:column}.weekdays-header{display:grid;grid-template-columns:repeat(7,1fr);text-align:center;font-weight:700;font-family:var(--font-display);font-size:.75rem;color:var(--text-muted);margin-bottom:.4rem;padding-bottom:.4rem;border-bottom:1px solid var(--border-color);flex-shrink:0}.weekday-cell{padding:.25rem 0}.weekday-cell.weekend{color:var(--color-special-lunar)}.days-grid{display:grid;grid-template-columns:repeat(7,1fr);grid-auto-rows:1fr;gap:.3rem;flex:1;min-height:0;padding-bottom:.5rem}.day-cell{position:relative;padding:.2rem;display:flex;flex-direction:column;align-items:center;justify-content:center;border-radius:var(--radius-sm);border:1px solid var(--border-color);background:var(--bg-secondary);cursor:pointer;transition:all var(--transition-fast);min-width:0;min-height:0;overflow:hidden}.day-cell:hover{border-color:var(--color-accent);z-index:2}.day-cell.empty{background:transparent;border:none;cursor:default;pointer-events:none}.day-cell.today{background:var(--color-today-bg);border-color:var(--color-today-border)}.day-cell.selected{border-color:var(--color-accent);background:var(--bg-card-hover);outline:2px solid var(--color-accent);outline-offset:-1px}.day-cell.special-day{background:var(--color-special-lunar-bg)}.special-badge{display:none}.lunar-num{font-family:var(--font-display);font-size:clamp(1.4rem,3.2vh,2.2rem);font-weight:800;line-height:1;color:var(--text-primary);display:flex;align-items:center;justify-content:center;flex:1;gap:.1rem}.day-cell.special-day .lunar-num{color:var(--color-special-lunar)}.leap-label{font-size:.65rem;font-weight:500;background:var(--color-gold-light);color:var(--color-gold);padding:1px 4px;border-radius:4px;border:1px solid var(--color-gold-border);vertical-align:middle}.solar-num{font-family:var(--font-sans);font-size:clamp(.65rem,1.4vh,.9rem);font-weight:600;color:var(--text-muted);line-height:1;position:absolute;bottom:.2rem;right:.3rem}.day-cell.today .solar-num{color:var(--color-accent)}.details-wrapper{padding:1rem 1.25rem;display:flex;flex-direction:column;gap:.75rem;overflow:hidden;min-height:0}.details-title-section{border-bottom:1px solid var(--border-color);padding-bottom:.6rem;flex-shrink:0}.details-subtitle{font-size:.7rem;text-transform:uppercase;letter-spacing:1px;color:var(--text-muted);margin-bottom:.15rem}.details-main-title{font-size:1.2rem;font-weight:800;color:var(--text-primary)}.details-info-grid{display:flex;flex-direction:column;gap:0;flex:1;min-height:0;overflow:hidden}.info-row{display:flex;justify-content:space-between;align-items:center;padding:.45rem 0;border-bottom:1px dashed var(--border-color)}.info-label{font-size:.78rem;color:var(--text-secondary);display:flex;align-items:center;gap:.4rem}.info-value{font-size:.82rem;font-weight:600;color:var(--text-primary);text-align:right}.info-value.highlight{color:var(--color-gold)}.info-icon{color:var(--text-muted)}.auspicious-grid{display:grid;grid-template-columns:1fr;gap:.2rem;background:var(--bg-primary);padding:.5rem;border-radius:var(--radius-sm);border:1px solid var(--border-color)}.auspicious-row{display:flex;justify-content:space-between;font-size:.75rem;padding:.2rem 0;border-bottom:1px solid var(--border-color)}.auspicious-row:last-child{border-bottom:none}.aus-name{font-weight:700;color:var(--color-special-lunar)}.aus-range{color:var(--text-secondary)}.details-cta-btn{width:100%;margin-top:auto;flex-shrink:0}.modal-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background:#020617a6;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);display:flex;justify-content:center;align-items:flex-start;overflow-y:auto;padding:2rem 1rem;z-index:1000}.modal-container{width:100%;max-width:550px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-xl);position:relative;margin:auto}.modal-header{padding:1.5rem;border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;align-items:center}.modal-title{font-size:1.25rem;font-weight:800}.btn-close{color:var(--text-muted);transition:color var(--transition-fast)}.btn-close:hover{color:var(--color-special-lunar)}.modal-body{padding:1.5rem;display:flex;flex-direction:column;gap:1.25rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-label{font-size:.85rem;font-weight:600;color:var(--text-secondary)}.input-row{display:grid;grid-template-columns:1fr;gap:1rem}@media (min-width: 480px){.input-row{grid-template-columns:1fr 1fr}}.input-field-wrapper{position:relative;display:flex;align-items:center}.input-icon{position:absolute;left:.75rem;color:var(--text-muted);pointer-events:none}.text-input,.date-input,.select-input{width:100%;padding:.75rem 1rem .75rem 2.25rem;border:1px solid var(--border-color);border-radius:var(--radius-md);background:var(--bg-primary);color:var(--text-primary);font-size:.95rem;transition:all var(--transition-fast)}.text-input:focus,.date-input:focus,.select-input:focus{border-color:var(--color-accent);box-shadow:0 0 0 3px #6366f126;background:var(--bg-secondary)}.textarea-input{width:100%;min-height:80px;padding:.75rem 1rem;border:1px solid var(--border-color);border-radius:var(--radius-md);background:var(--bg-primary);color:var(--text-primary);font-size:.95rem;resize:vertical;transition:all var(--transition-fast)}.textarea-input:focus{border-color:var(--color-accent);box-shadow:0 0 0 3px #6366f126;background:var(--bg-secondary)}.date-pickers-stack{display:flex;flex-direction:column;gap:1.25rem}.lunar-pickers-group{display:grid;grid-template-columns:1fr 1fr 1.5fr;gap:.5rem}.lunar-select{padding:.75rem .5rem;border:1px solid var(--border-color);border-radius:var(--radius-md);background:var(--bg-primary);color:var(--text-primary);font-size:.9rem;transition:all var(--transition-fast);text-align:center}.lunar-select:focus{border-color:var(--color-accent);background:var(--bg-secondary)}.toggle-row{display:flex;align-items:center;gap:.75rem;cursor:pointer;-webkit-user-select:none;user-select:none;padding:.5rem 0}.checkbox-custom{width:20px;height:20px;border-radius:6px;border:2px solid var(--border-color);display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast);color:#fff}.toggle-row:hover .checkbox-custom{border-color:var(--color-accent)}.toggle-row.active .checkbox-custom{background:var(--color-accent);border-color:var(--color-accent)}.toggle-label-group{display:flex;flex-direction:column}.toggle-label-main{font-size:.95rem;font-weight:600}.toggle-label-sub{font-size:.75rem;color:var(--text-muted)}.modal-footer{padding:1.25rem 1.5rem;border-top:1px solid var(--border-color);display:flex;justify-content:flex-end;gap:.75rem}.theme-switch{display:flex;align-items:center;gap:.4rem;padding:.4rem .65rem;border-radius:var(--radius-md);border:1px solid var(--border-color);background:var(--bg-secondary);color:var(--text-primary);font-size:.8rem;font-weight:600;transition:all var(--transition-fast)}.theme-switch:hover{background:var(--border-color)}.app-footer{text-align:center;padding:.75rem 0;color:var(--text-muted);font-size:.85rem;border-top:1px solid var(--border-color);flex-shrink:0}.lunar-result-display{margin-top:.4rem;font-size:.85rem;color:var(--text-secondary);padding:.4rem .75rem;background:var(--color-gold-light);border:1px solid var(--color-gold-border);border-radius:var(--radius-md);color:var(--color-gold)}.sync-flash{animation:borderFlash .6s ease-out}@keyframes borderFlash{0%{border-color:var(--color-accent);box-shadow:0 0 10px var(--color-accent)}to{border-color:var(--border-color);box-shadow:none}}.recurrence-block{border:1px solid var(--border-color);border-radius:var(--radius-md);overflow:hidden}.recurrence-block .toggle-row{padding:.6rem .9rem;margin:0}.recurrence-block .toggle-row.active{border-bottom:1px solid var(--border-color)}.recurrence-options{padding:.75rem .9rem;display:flex;flex-direction:column;gap:.75rem;background:var(--bg-primary)}.recurrence-controls{display:flex;align-items:center;gap:.5rem}.repeat-preview{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:.6rem .75rem}.repeat-preview-title{font-size:.72rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:.4rem}.repeat-preview-list{list-style:none;display:flex;flex-direction:column;gap:0;max-height:150px;overflow-y:auto}.repeat-preview-item{display:flex;align-items:center;gap:.4rem;font-size:.8rem;padding:.25rem 0;border-bottom:1px dashed var(--border-color)}.repeat-preview-item:last-child{border-bottom:none}.rp-index{color:var(--text-muted);min-width:1.2rem;font-size:.72rem}.rp-lunar{font-weight:700;color:var(--color-special-lunar);min-width:6.5rem}.rp-sep{color:var(--text-muted);font-size:.72rem}.rp-solar{color:var(--text-secondary)}.modal-container form{display:block}.repeat-preview-header{display:flex;align-items:center;gap:.4rem;padding-bottom:.35rem;margin-bottom:.1rem;border-bottom:2px solid var(--border-color)}.rp-col-label{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.4px}.rp-col-lunar{color:var(--color-special-lunar);min-width:6.5rem}.rp-col-solar{color:var(--color-accent)}.nav-btn-group{display:flex;align-items:center;gap:.25rem}.btn-nav{display:flex;align-items:center;padding:.35rem .6rem;font-size:.78rem;font-weight:600;font-family:var(--font-display);border:1px solid var(--border-color);border-radius:var(--radius-md);background:var(--bg-secondary);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap}.btn-nav:hover{background:var(--border-color);color:var(--color-accent)}.btn-nav:active{transform:scale(.97)}.btn-nav-today{color:var(--color-accent);border-color:var(--color-accent)}.btn-nav-today:hover{background:var(--color-today-bg);color:var(--color-accent)}.lunar-year-inline{font-size:.85em;font-weight:600;color:var(--text-secondary);margin-left:.4rem}.btn-today{padding:.4rem .75rem;font-size:.8rem}.year-select{margin-left:.4rem;padding:.1rem .3rem;font-size:.9em;font-weight:700;font-family:var(--font-display);color:var(--text-primary);background:transparent;border:1px solid var(--border-color);border-radius:var(--radius-sm);cursor:pointer;vertical-align:middle;transition:border-color var(--transition-fast)}.year-select:hover,.year-select:focus{border-color:var(--color-accent);outline:none}.year-display-btn{display:inline-flex;align-items:center;margin-left:.35rem;padding:.1rem .35rem;font-size:1em;font-weight:800;font-family:var(--font-display);color:var(--text-primary);background:transparent;border:1px solid transparent;border-radius:var(--radius-sm);cursor:pointer;vertical-align:middle;transition:border-color var(--transition-fast),background var(--transition-fast);line-height:1}.year-display-btn:hover{border-color:var(--border-color);background:var(--bg-secondary)}.year-input-edit{display:inline-block;margin-left:.35rem;width:5rem;padding:.1rem .35rem;font-size:1em;font-weight:800;font-family:var(--font-display);color:var(--text-primary);background:var(--bg-secondary);border:1px solid var(--color-accent);border-radius:var(--radius-sm);vertical-align:middle;outline:none;-moz-appearance:textfield}.year-input-edit::-webkit-outer-spin-button,.year-input-edit::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}
