.yearly-calendar{background-color:#f5f5f5;min-height:100vh}.months-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem;max-width:1200px;margin:0 auto}.month-container{background:#fff;border-radius:12px;padding:1rem;box-shadow:0 2px 8px #0000001a}.month-header{text-align:center;margin-bottom:1rem;padding-bottom:.5rem}.month-header h3{margin:0;color:#333;font-size:1.1rem;font-weight:600}.custom-calendar{width:100%}.calendar-header{display:grid;grid-template-columns:repeat(7,1fr);margin-bottom:8px}.weekday{padding:8px 4px;text-align:center;font-size:1rem;font-weight:500;color:#666;border-radius:4px}.calendar-body{display:grid;grid-template-columns:repeat(7,1fr);gap:5px}.calendar-day{position:relative;aspect-ratio:1;display:flex;flex-direction:column;align-items:center;justify-content:center;border-radius:4px;cursor:pointer;transition:all .2s ease;background-color:#fff}.calendar-day:hover{background-color:#f5f5f5}.calendar-day.other-month{color:#ccc;background-color:#fafafa}.calendar-day.other-month:hover{background-color:#f0f0f0}.calendar-day.today{border-color:#1890ff;font-weight:600}.calendar-day.completed{background-color:#52c41a!important;color:#fff!important;border-color:#52c41a;border-radius:50%}.calendar-day.completed:hover{background-color:#40a9ff!important}.day-number{font-size:.875rem;line-height:1}.note-indicator{font-size:.6rem;line-height:1;margin-top:2px}.yearly-calendar-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;height:200px;color:#666}.loading-spinner{width:32px;height:32px;border:3px solid #f3f3f3;border-top:3px solid #1890ff;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:1rem}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (max-width: 768px){.months-grid{grid-template-columns:1fr;gap:1rem}.month-container{padding:.75rem}.month-header h3{font-size:1rem}.calendar-day{min-height:32px}.day-number{font-size:1.25rem}.note-indicator{font-size:.5rem}}.logo{height:6em;padding:1.5em;will-change:filter;transition:filter .3s}.logo:hover{filter:drop-shadow(0 0 2em #646cffaa)}.logo.react:hover{filter:drop-shadow(0 0 2em #61dafbaa)}@keyframes logo-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (prefers-reduced-motion: no-preference){a:nth-of-type(2) .logo{animation:logo-spin infinite 20s linear}}.card{padding:2em}.read-the-docs{color:#888}.app-layout{min-height:100vh;background:#f5f5f5}.header-content{display:flex;justify-content:space-between;align-items:center;max-width:1200px;margin:0 auto}.app-content{padding:24px;max-width:1200px;margin:0 auto;width:100%}.app{display:flex;flex-direction:column;height:100vh;background-color:#f5f5f5}.adm-nav-bar{position:sticky;top:0;z-index:1000;background:#fff;border-bottom:1px solid #f0f0f0;box-shadow:0 2px 8px #0000001a}.app-body{flex:1;overflow-y:auto;padding:0;background-color:#fff}.app-footer{position:fixed;left:0;bottom:0;width:100%;background:#fff;border-top:1px solid #f0f0f0}.stats-card{margin:12px;border-radius:12px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none}.stats-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.stats-header h3{margin:0;font-size:18px;font-weight:600}.completion-rate{text-align:right}.rate-number{font-size:24px;font-weight:700;display:block}.rate-label{font-size:12px;opacity:.8}.stat-item{text-align:center;padding:8px}.stat-number{font-size:20px;font-weight:700;display:block;margin-bottom:4px}.stat-label{font-size:12px;opacity:.8}.habit-card{display:flex;flex-direction:column;align-items:center;gap:20px;margin:20px;padding:20px;border-radius:10px;border:1px solid #d9d9e0;box-shadow:0 2px 8px #0000001a;background-color:#fff}.habit-header{width:100%;display:flex;justify-content:space-between;align-items:center}.habit-info{flex:1;min-width:0}.habit-name{font-size:18px;font-weight:600;line-height:1.4}.habit-actions{display:flex;align-items:center;gap:8px;flex-shrink:0}.stat-badge{display:inline-block;padding:2px 8px;background-color:#f0f0f0;border-radius:12px;font-size:12px;color:#666}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:64px 0;color:#999}.chart-card{margin:12px;border-radius:12px;border:none}.chart-card h3{margin:0 0 16px;font-size:16px;font-weight:600}.week-chart{display:flex;justify-content:space-between;align-items:end;height:120px;padding:0 8px}.day-item{display:flex;flex-direction:column;align-items:center;gap:8px}.day-bar{width:24px;height:60px;background-color:#f0f0f0;border-radius:12px;transition:all .3s ease}.day-bar.completed{background:linear-gradient(to top,#52c41a,#73d13d);height:80px}.day-label{font-size:12px;color:#666}.profile-header{text-align:center;padding:20px}.avatar{width:80px;height:80px;border-radius:50%;background-color:#f0f0f0;display:flex;align-items:center;justify-content:center;margin:0 auto 16px;color:#999}.profile-header h3{margin:0 0 4px;font-size:18px;font-weight:600}.profile-header p{margin:0;color:#666;font-size:14px}.popup-header{padding:16px 16px 0;border-bottom:1px solid #f0f0f0}.popup-header h3{margin:0;font-size:18px;font-weight:600;text-align:center;padding-bottom:16px}.popup-body{padding:16px}@media (max-width: 375px){.stat-number{font-size:18px}.rate-number{font-size:22px}}@supports (padding: max(0px)){.app{padding-top:max(0px,env(safe-area-inset-top))}}.stats-content{display:flex;justify-content:space-around;align-items:center;padding:16px 0}.stat-item{text-align:center}.stat-label{display:block;font-size:14px;color:#666;margin-bottom:4px}.stat-value{display:block;font-size:24px;font-weight:700;color:#1890ff}.habits-container{background:#fff;border-radius:8px;overflow:hidden;box-shadow:0 2px 8px #0000001a}.habit-content{display:flex;justify-content:space-between;align-items:center;width:100%}.habit-info{flex:1;margin-right:16px}.habit-header{display:flex;align-items:center;gap:12px;margin-bottom:8px}.habit-description{color:#666;margin:8px 0;font-size:14px}.habit-stats{color:#999;font-size:12px}.habit-action{flex-shrink:0}.empty-state{border:2px dashed #d9d9d9;background:#fafafa}.empty-content{text-align:center;padding:40px 20px;color:#999}.empty-icon{font-size:48px;color:#d9d9d9;margin-bottom:16px}.popup-body .adm-list-body{border:none}@media (max-width: 768px){.app-header{padding:0 16px}.header-content{flex-direction:column;gap:16px;padding:16px 0}.app-content{padding:16px}.habit-content{flex-direction:column;align-items:flex-start;gap:16px}.habit-action,.habit-action button{width:100%}.stats-content{flex-direction:column;gap:16px}}.ant-list-item{padding:0;border:none}.ant-card-body{padding:20px}.ant-btn-primary{border-radius:6px}.ant-modal-header{border-radius:8px 8px 0 0}.ant-modal-content{border-radius:8px}.habit-detail-page{padding:0}.habit-detail-header{margin-bottom:16px}.habit-detail-info h2{margin:0 0 8px;font-size:24px;font-weight:600}.habit-stats-detail{margin-top:16px}.habit-calendar-container{margin-bottom:16px}.calendar-page{height:100vh;display:flex;flex-direction:column;background-color:#f5f5f5}.calendar-page-content{flex:1;overflow-y:auto;padding:12px}.habit-detail-card{margin-bottom:16px;border-radius:12px;border:none}.calendar-card{border-radius:12px;border:none}.calendar-card h3{margin:0 0 16px;font-size:16px;font-weight:600}.error-container{display:flex;align-items:center;justify-content:center;height:100vh;color:#999;font-size:16px}@media (prefers-reduced-motion: reduce){*{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}.fade-in{opacity:1;transform:translateY(0)}.fade-out{opacity:0;transform:translateY(-10px)}.slide-in-right{opacity:1;transform:translate(0)}.slide-out-right{opacity:0;transform:translate(100%)}.slide-in-left{opacity:1;transform:translate(0)}.slide-out-left{opacity:0;transform:translate(-100%)}.transitioning{pointer-events:none}.habits-page,.stats-page,.profile-page{min-height:100%;padding-bottom:20px}.habit-detail-page{padding:0;transition:all .3s cubic-bezier(.4,0,.2,1)}.habit-card{transition:all .2s ease;transform:translateZ(0)}.habit-card:active{transform:scale(.98) translateZ(0);background-color:#f5f5f5}.stats-card{margin:12px;border-radius:12px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;transition:all .3s ease;transform:translateZ(0)}.ant-btn{transition:all .2s cubic-bezier(.4,0,.2,1);transform:translateZ(0)}.ant-btn:active{transform:scale(.95) translateZ(0)}.adm-tab-bar{transition:all .3s ease}.adm-tab-bar-item{transition:all .2s ease}.adm-popup{transition:all .3s cubic-bezier(.4,0,.2,1)}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:64px 0;color:#999;transition:all .3s ease}@media (prefers-reduced-motion: reduce){.page-content,.habit-card,.stats-card,.ant-btn{transition:none}}*{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-text-size-adjust:100%;-webkit-tap-highlight-color:transparent}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;line-height:1.5;color:#333;background-color:#f5f5f5;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow-x:hidden}#root{height:100vh;overflow:hidden}.app-body{-webkit-overflow-scrolling:touch;overscroll-behavior:contain}button{-webkit-appearance:none;border:none;outline:none}input{-webkit-appearance:none;border-radius:0}.habit-card,.stats-card{-webkit-user-select:none;user-select:none;-webkit-touch-callout:none}@media (max-width: 768px){html{font-size:14px}}@media (max-width: 375px){html{font-size:13px}}@media (prefers-color-scheme: dark){body{background-color:#000;color:#fff}}
