*{margin:0;padding:0;box-sizing:border-box;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
body{min-height:100vh;background:no-repeat center center fixed;background-size:cover;font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;color:#fff}
.glass{background:rgba(255,255,255,0.18);backdrop-filter:blur(24px) saturate(200%);-webkit-backdrop-filter:blur(24px) saturate(200%);border:1px solid rgba(255,255,255,0.25);border-radius:20px}
.glass-tooltip{position:fixed;background:rgba(20,20,30,0.95);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,0.3);border-radius:10px;padding:6px 12px;font-size:12px;font-weight:500;color:#fff;white-space:nowrap;z-index:10000;pointer-events:none;opacity:0;transform:translateY(-8px);transition:opacity .2s ease,transform .2s ease;box-shadow:0 4px 15px rgba(0,0,0,0.3);max-width:300px;white-space: pre-line; text-align: center;line-height:1.4}
.glass-tooltip::before{content:'';position:absolute;bottom:-5px;left:50%;transform:translateX(-50%);width:0;height:0;border-left:6px solid transparent;border-right:6px solid transparent;border-top:6px solid rgba(20,20,30,0.95)}
.glass-tooltip.show{opacity:1;transform:translateY(0)}
.glass-tooltip.bottom::before{top:-5px;bottom:auto;border-bottom:6px solid rgba(20,20,30,0.95);border-top:none}
.container{max-width:1400px;margin:0 auto;padding:30px 20px 100px}
.clock-box{background:transparent!important;backdrop-filter:none!important;border:none!important;box-shadow:none!important;padding:20px 40px 15px!important;margin-bottom:20px!important;text-align:center}
.clock-box h1{font-size:56px;font-weight:300;letter-spacing:2px;margin:0;color:#fff;text-shadow:0 2px 10px rgba(0,0,0,0.3)}
.clock-box p{font-size:16px;opacity:.85;margin-top:8px;color:#fff}
.grid-box{display:grid;grid-template-columns:repeat(12,1fr);gap:20px}
.app-item{grid-column:span 1;width:90px;height:90px;padding:16px!important;text-align:center;text-decoration:none!important;color:#fff!important;transition:all .25s cubic-bezier(0.25,0.46,0.45,0.94);display:flex;flex-direction:column;align-items:center;justify-content:center;box-sizing:border-box;margin:0 auto;cursor:pointer}
.app-item:hover{transform:translateY(-6px);background:rgba(255,255,255,0.28)!important}
.app-item .icon{font-size:32px!important;margin-bottom:6px!important;transition:transform .25s ease;display:flex;align-items:center;justify-content:center;line-height:1}
.app-item:hover .icon{transform:scale(1.08)}
.app-item .title{font-size:13px!important}
.app-item-add {
    border: 2px dashed rgba(255,255,255,0.25) !important;
    background: rgba(255,255,255,0.08) !important;
    transition: all 0.25s ease;
}
.app-item-add:hover {
    border-color: rgba(255,255,255,0.5) !important;
    background: rgba(255,255,255,0.18) !important;
    transform: translateY(-6px);
}
.calendar-card{grid-column:span 4;padding:18px 20px}
.calendar-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;font-size:16px;font-weight:500;color:#fff}
.calendar-nav{display:flex;gap:8px}
.calendar-nav span{cursor:pointer;padding:4px 10px;border-radius:8px;background:rgba(255,255,255,0.15);transition:all .2s ease;font-size:13px;display:inline-flex;align-items:center;justify-content:center}
.calendar-nav span:hover{background:rgba(255,255,255,0.35);transform:scale(1.05)}
.calendar-weekdays{display:grid;grid-template-columns:repeat(7,1fr);text-align:center;margin-bottom:8px;font-size:13px;opacity:.85;color:#fff;font-weight:500}
.calendar-weekdays span:first-child,.calendar-weekdays span:last-child{color:#ff5c5c}
.calendar-days{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}
.calendar-day{text-align:center;padding:8px 3px;border-radius:10px;cursor:pointer;transition:all .2s ease;font-size:14px;color:#fff}
.calendar-day:hover{background:rgba(255,255,255,0.25);transform:scale(1.02)}
.calendar-day.today{background:rgba(0,122,255,0.5);font-weight:700}
.calendar-day.other-month{opacity:.4}
.calendar-day.weekend{color:#ff5c5c}
.calendar-bottom-text{font-size:9px;margin-top:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.calendar-bottom-text.holiday{color:#ff5c5c!important}
.calendar-bottom-text.solar-term{color:#4cd964!important}
.memo-card{grid-column:span 4;padding:18px 20px;display:flex;flex-direction:column;overflow:hidden}
.memo-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}
.memo-header h4{font-size:16px;font-weight:500;color:#fff;margin:0}
.memo-add{cursor:pointer;width:32px;height:32px;border-radius:50%;background:rgba(255,255,255,0.2);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,0.35);color:#fff;font-size:18px;transition:all .25s cubic-bezier(0.25,0.46,0.45,0.94);display:inline-flex;align-items:center;justify-content:center;box-shadow:0 2px 8px rgba(0,0,0,0.1);line-height:1}
.memo-add:hover{background:rgba(255,255,255,0.45);transform:scale(1.08);border-color:rgba(255,255,255,0.6);box-shadow:0 4px 12px rgba(0,0,0,0.15)}
.memo-add:active{transform:scale(.95)}
.memo-list{flex:1;max-height:240px;overflow-y:auto}
.memo-list::-webkit-scrollbar{width:4px}
.memo-list::-webkit-scrollbar-track{background:rgba(255,255,255,0.1);border-radius:4px}
.memo-list::-webkit-scrollbar-thumb{background:rgba(255,255,255,0.3);border-radius:4px}
.memo-item{display:flex;align-items:center;gap:8px;padding:8px 6px;border-bottom:1px solid rgba(255,255,255,0.12);transition:background-color .2s ease,border-radius .2s ease}
.memo-item:hover{background:rgba(255,255,255,0.12);border-radius:8px}
.memo-check{width:16px;height:16px;cursor:pointer;accent-color:#007aff;flex-shrink:0}
.memo-text{flex:1;font-size:13px;background:transparent;border:none;color:#fff;padding:4px 0;outline:none}
.memo-text:focus{outline:none;border-bottom:1px solid rgba(255,255,255,0.6)}
.memo-text.completed{text-decoration:line-through;opacity:.6}
.memo-delete{opacity:.5;cursor:pointer;padding:0 6px;font-size:14px;color:#fff;transition:all .2s ease;flex-shrink:0}
.memo-delete:hover{opacity:1;transform:scale(1.1)}
.memo-empty{text-align:center;opacity:.5;padding:25px;font-size:13px;color:#fff}
.tools-grid{grid-column:span 4;display:grid;grid-template-columns:repeat(2,1fr);gap:12px;min-height:200px}
.tool-card{padding:14px 10px;text-align:center;display:flex;flex-direction:column;justify-content:center;align-items:center;min-height:100%;background:rgba(255,255,255,0.18);backdrop-filter:blur(24px);border-radius:20px;border:1px solid rgba(255,255,255,0.25);overflow:hidden;position:relative}
.tool-card:hover{background:rgba(255,255,255,0.22)}
.tool-header{display:flex;justify-content:center;align-items:center;width:100%;font-size:14px;font-weight:500;color:#fff;margin-bottom:10px;padding-bottom:6px;border-bottom:1px solid rgba(255,255,255,0.2)}
.tool-refresh-btn-fixed{position:absolute;top:8px;right:8px;background:rgba(255,255,255,0.2);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,0.3);color:#fff;width:26px;height:26px;border-radius:50%;cursor:pointer;font-size:12px;transition:all .25s ease;display:inline-flex;align-items:center;justify-content:center;z-index:10;line-height:1}
.tool-refresh-btn-fixed:hover{background:rgba(255,255,255,0.4);transform:scale(1.08);border-color:rgba(255,255,255,0.6)}
/* ========== 工具栏加载状态 ========== */
.tools-grid-loading {
    display: flex !important;
    align-items: center;
    justify-content: center;
    min-height: 200px;
}
.tools-loading-text {
    color: rgba(255,255,255,0.4);
    font-size: 13px;
    grid-column: span 2;
    text-align: center;
}
.timer-display, .countdown-display {
    font-family: 'SF Mono', 'Consolas', 'Menlo', monospace;
    font-size: 26px;
    font-weight: 600;
    font-variant-numeric: tabular-nums;
    letter-spacing: 3px;
}
.timer-buttons,.countdown-buttons{display:flex;justify-content:center;gap:10px;margin-top:8px}
.icon-btn{background:rgba(255,255,255,0.2);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,0.35);color:#fff;width:36px;height:36px;border-radius:50%;cursor:pointer;font-size:16px;transition:all .25s cubic-bezier(0.25,0.46,0.45,0.94);display:inline-flex;align-items:center;justify-content:center;box-shadow:0 2px 8px rgba(0,0,0,0.1);margin:0 4px;line-height:1}
.icon-btn:hover{background:rgba(255,255,255,0.45);transform:scale(1.1);border-color:rgba(255,255,255,0.6);box-shadow:0 4px 12px rgba(0,0,0,0.15)}
.icon-btn:active{transform:scale(.95)}
.icon-btn.setup-btn{background:rgba(0,122,255,0.3);border-color:rgba(0,122,255,0.5)}
.icon-btn.setup-btn:hover{background:rgba(0,122,255,0.5);border-color:rgba(0,122,255,0.8)}
.icon-btn.start-btn{background:rgba(52,199,89,0.3);border-color:rgba(52,199,89,0.5)}
.icon-btn.start-btn:hover{background:rgba(52,199,89,0.5);border-color:rgba(52,199,89,0.8)}
.icon-btn.stop-btn{background:rgba(255,59,48,0.3);border-color:rgba(255,59,48,0.5)}
.icon-btn.stop-btn:hover{background:rgba(255,59,48,0.5);border-color:rgba(255,59,48,0.8)}
.tool-card canvas{display:block;margin:0 auto}
canvas{background:rgba(255,255,255,0.15);backdrop-filter:blur(10px);border-radius:50%;box-shadow:0 4px 16px rgba(0,0,0,0.1)}
.soup-text{font-size:12px;line-height:1.5;margin:10px 0;min-height:55px;font-style:italic;color:#fff;padding:0 5px}
.herb-content,.prescription-content{text-align:left;font-size:11px;line-height:1.5;color:rgba(255,255,255,0.9);width:100%}
.herb-name,.prescription-name{font-size:13px;font-weight:600;color:#fff;margin-bottom:6px}
.herb-detail,.prescription-detail{font-size:10px;color:rgba(255,255,255,0.7);margin:3px 0}
.holiday-content,.memorial-content{text-align:center;width:100%}
.holiday-name,.memorial-name{font-size:14px;font-weight:600;color:#fff;margin-bottom:5px}
.holiday-date,.memorial-date{font-size:11px;color:rgba(255,255,255,0.6);margin-bottom:8px}
.holiday-countdown,.memorial-countdown{font-size:18px;font-weight:700;color:#ff5c5c}
.holiday-countdown strong,.memorial-countdown strong{font-size:22px}
.water-content{text-align:center;width:100%}
.water-icon{font-size:13px;margin-bottom:8px}
.water-progress{width:100%;height:6px;background:rgba(255,255,255,0.2);border-radius:3px;overflow:hidden;margin:8px 0}
.water-progress-bar{height:100%;background:#4cd964;border-radius:3px;transition:width .3s ease}
.water-buttons{display:flex;gap:10px;justify-content:center;margin-top:8px}
.water-btn{background:rgba(255,255,255,0.2);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,0.3);color:#fff;padding:4px 12px;border-radius:20px;font-size:11px;cursor:pointer;transition:all .2s ease}
.water-btn:hover{background:rgba(255,255,255,0.35);transform:scale(1.02)}
.reset-btn{background:rgba(255,59,48,0.3);border-color:rgba(255,59,48,0.5)}
.reset-btn:hover{background:rgba(255,59,48,0.5)}
.quote-content{text-align:center;width:100%}
.quote-text{font-size:12px;font-style:italic;line-height:1.5;color:#fff;margin-bottom:8px}
.quote-author{font-size:11px;color:rgba(255,255,255,0.6)}
.poetry-content{text-align:center;width:100%}
.poetry-title{font-size:12px;font-weight:500;color:#fff;margin-bottom:8px}
.poetry-text{font-size:11px;line-height:1.6;color:rgba(255,255,255,0.85)}
.checkin-container{display:flex;flex-direction:column;align-items:center;justify-content:center;width:100%}
.checkin-progress-ring{position:relative;width:120px;height:120px;margin:10px auto}
.checkin-svg{width:100%;height:100%;transform:rotate(-90deg)}
.checkin-bg{stroke:rgba(255,255,255,0.2)}
.checkin-progress{stroke:#007aff;transition:stroke-dashoffset .5s ease,stroke .3s ease}
.checkin-content{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center;width:100%}
.checkin-count{font-size:20px;font-weight:700;color:#fff;line-height:1.2}
.checkin-name{font-size:11px;color:rgba(255,255,255,0.7);margin-top:4px}
.checkin-btn{background:linear-gradient(135deg,#007aff,#0055cc);border:none;color:#fff;font-size:18px;font-weight:600;padding:8px 24px;border-radius:30px;cursor:pointer;margin-top:10px;transition:all .2s ease;box-shadow:0 4px 15px rgba(0,122,255,0.3)}
.checkin-btn:hover{transform:scale(1.05);box-shadow:0 6px 20px rgba(0,122,255,0.4)}
.checkin-btn:active{transform:scale(.98)}
.dock-bar{position:fixed;bottom:20px;left:50%;transform:translateX(-50%);display:flex;gap:14px;padding:12px 24px;border-radius:32px;z-index:999;background:rgba(255,255,255,0.2);backdrop-filter:blur(24px);border:1px solid rgba(255,255,255,0.3);transition:all .3s ease}
.dock-bar:hover{background:rgba(255,255,255,0.25);gap:16px;padding:12px 26px}
.dock-item{width:52px;height:52px;display:flex;align-items:center;justify-content:center;font-size:26px;border-radius:16px;background:rgba(255,255,255,0.15);transition:all .25s cubic-bezier(0.34,1.2,0.64,1);text-decoration:none!important;color:#fff!important;line-height:1;cursor:pointer}
.dock-item:hover{transform:translateY(-10px) scale(1.12);background:rgba(255,255,255,0.35);box-shadow:0 8px 25px rgba(0,0,0,0.2)}
.alert-overlay,.modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,0.5);backdrop-filter:blur(5px);z-index:1000;display:flex;justify-content:center;align-items:center;animation:fadeIn .2s ease}
.alert-box,.modal-box{background:rgba(30,30,40,0.95);backdrop-filter:blur(20px);border-radius:28px;padding:24px 28px;text-align:center;border:1px solid rgba(255,255,255,0.2);animation:bounceIn .35s cubic-bezier(0.34,1.2,0.64,1);min-width:280px}
.alert-box p,.modal-box p{font-size:18px;margin-bottom:20px;color:#fff}
.alert-box button,.modal-box button{background:#007aff;border:none;color:#fff;padding:8px 24px;border-radius:25px;cursor:pointer;font-size:14px;transition:all .2s ease;margin:0 8px;display:inline-flex;align-items:center;justify-content:center;line-height:1}
.alert-box button:hover,.modal-box button:hover{background:#0055cc;transform:scale(1.02)}
.alert-box .cancel-btn,.modal-box .cancel-btn{background:rgba(255,255,255,0.2)}
.alert-box .cancel-btn:hover,.modal-box .cancel-btn:hover{background:rgba(255,255,255,0.35)}
.timer-modal .modal-box{min-width:260px}
.timer-modal input{background:rgba(255,255,255,0.15);border:1px solid rgba(255,255,255,0.3);color:#fff;padding:12px 16px;border-radius:12px;font-size:18px;width:100%;margin-bottom:20px;text-align:center}
.timer-modal input:focus{outline:none;border-color:#007aff;background:rgba(255,255,255,0.25)}
.datetime-modal .modal-box{min-width:300px}
.datetime-modal input{background:rgba(255,255,255,0.15);border:1px solid rgba(255,255,255,0.3);color:#fff;padding:12px 16px;border-radius:12px;font-size:16px;width:100%;margin-bottom:20px;box-sizing:border-box}
.datetime-modal input:focus{outline:none;border-color:#007aff;background:rgba(255,255,255,0.25)}
.datetime-modal input[type="datetime-local"]{color-scheme:dark}
.datetime-modal input[type="datetime-local"]::-webkit-calendar-picker-indicator{filter:invert(1);cursor:pointer}
.footer-bar{position:fixed;bottom:20px;right:20px;display:flex;gap:12px;z-index:998}
.copyright{background:rgba(0,0,0,0.5);backdrop-filter:blur(10px);padding:6px 14px;border-radius:20px;font-size:11px;color:rgba(255,255,255,0.7);letter-spacing:.5px}
.context-menu{position:fixed;background:rgba(30,30,40,0.95);backdrop-filter:blur(20px);border-radius:12px;border:1px solid rgba(255,255,255,0.2);box-shadow:0 8px 25px rgba(0,0,0,0.3);z-index:10002;min-width:160px;overflow:hidden;animation:fadeIn 0.15s ease}
.context-menu-item{padding:10px 16px;font-size:14px;color:#fff;cursor:pointer;transition:background 0.2s ease}
.context-menu-item:hover{background:rgba(255,255,255,0.15)}
.context-menu-divider{height:1px;background:rgba(255,255,255,0.1);margin:4px 0}
.settings-btn{position:fixed;top:20px;right:120px;z-index:1000;width:36px;height:36px;border-radius:50%;background:rgba(0,0,0,0.5);backdrop-filter:blur(10px);display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:18px;transition:all 0.25s ease}
.settings-btn:hover{background:rgba(0,0,0,0.7);transform:scale(1.05)}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes bounceIn{0%{transform:scale(0.85);opacity:0}60%{transform:scale(1.02)}100%{transform:scale(1);opacity:1}}
@media (max-width:1000px){.app-item{grid-column:span 2}.calendar-card,.memo-card,.tools-grid{grid-column:span 6}}
@media (max-width:700px){.container{padding:20px 20px 100px}.clock-box h1{font-size:48px}.app-item{grid-column:span 3;width:75px;height:75px;padding:12px!important}.app-item .icon{font-size:28px!important}.app-item .title{font-size:11px!important}.calendar-card,.memo-card,.tools-grid{grid-column:span 12}.tools-grid{grid-template-columns:repeat(2,1fr)}.dock-bar{gap:8px;padding:10px 18px}.dock-item{width:45px;height:45px;font-size:22px}.footer-bar{bottom:90px;right:15px;flex-direction:column;align-items:flex-end;gap:8px}}
@media (max-width:480px){.clock-box h1{font-size:36px}.clock-box p{font-size:13px}.app-item{width:65px;height:65px;padding:8px!important}.app-item .icon{font-size:24px!important}.app-item .title{font-size:10px!important}.tools-grid{grid-template-columns:1fr}.timer-display,.countdown-display{font-size:20px;white-space:nowrap}.footer-bar{bottom:85px}}