:root{--school-blue-primary: #1F6FAD;--school-blue-light: #5C9FD6;--school-blue-dark: #124A75;--rgb-school-blue-primary: 31, 111, 173;--rgb-school-blue-light: 92, 159, 214;--color-accent-blue: var(--school-blue-light);--color-accent-cyan: #4DD0E1;--color-accent-orange: #FF8A65;--color-accent-purple: #BA68C8;--rgb-accent-cyan: 77, 208, 225;--rgb-accent-orange: 255, 138, 101;--rgb-accent-purple: 186, 104, 200;--temp-hot: #FF7043;--temp-warm: #FFCA28;--temp-cool: #26C6DA;--temp-cold: #42A5F5;--temp-freezing: #5C6BC0;--temp-neutral: #E0E0E0;--rgb-temp-hot: 255, 112, 67;--rgb-temp-cold: 66, 165, 245;--text-primary: rgba(255, 255, 255, .95);--text-secondary: rgba(255, 255, 255, .65);--text-tertiary: rgba(255, 255, 255, .45);--surface-glass: rgba(31, 111, 173, .15);--surface-glass-light: rgba(255, 255, 255, .1);--surface-glass-heavy: rgba(10, 25, 40, .75);--border-subtle: rgba(255, 255, 255, .08);--border-highlight: rgba(255, 255, 255, .15);--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-6: 24px;--space-8: 32px;--space-10: 40px;--radius-md: 16px;--radius-lg: 24px;--radius-full: 9999px;--blur-glass: 16px;--shadow-subtle: 0 4px 12px rgba(0, 0, 0, .1);--shadow-card: 0 8px 24px rgba(0, 0, 0, .2);--glow-inner-white: inset 0 1px 0 0 rgba(255, 255, 255, .1);--glow-white-medium: rgba(255, 255, 255, .4);--font-family-system: "HarmonyOS Sans", "Inter", "Microsoft YaHei", "PingFang SC", sans-serif;--font-family-serif: "KaiTi", "楷体", "STKaiti", serif;--font-weight-regular: 400;--font-weight-medium: 500;--font-weight-bold: 600;--text-sm: 18px;--text-base: 22px;--text-lg: 28px;--text-xl: 36px;--text-2xl: 48px;--text-3xl: 64px;--text-display-1: 120px;--text-display-2: 220px;--transition-fast: .2s cubic-bezier(.4, 0, .2, 1);--transition-normal: .4s cubic-bezier(.4, 0, .2, 1)}*,*:before,*:after{box-sizing:border-box}html,body{width:100%;height:100%;margin:0;padding:0;overflow:hidden;overscroll-behavior:none}body{font-family:var(--font-family-system);color:var(--text-primary);line-height:1.5;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-user-select:none;user-select:none}body{background-color:#050505;background-image:radial-gradient(circle at 15% 50%,rgba(var(--rgb-school-blue-primary),.4),transparent 40%),radial-gradient(circle at 85% 30%,rgba(var(--rgb-school-blue-light),.3),transparent 40%),linear-gradient(#0000001a,#0000004d);position:relative;z-index:0}body:before{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(at 0% 0%,rgba(var(--rgb-school-blue-primary),.5) 0px,transparent 60%),radial-gradient(at 100% 0%,rgba(var(--rgb-school-blue-light),.4) 0px,transparent 60%),radial-gradient(at 100% 100%,rgba(38,198,218,.3) 0px,transparent 60%);background-size:120% 120%;animation:gradient-flow 30s ease infinite alternate;will-change:transform;z-index:-1;pointer-events:none}@keyframes gradient-flow{0%{transform:translate(0) scale(1)}to{transform:translate(-2%,-2%) scale(1.05)}}.glass-panel{background:var(--surface-glass);backdrop-filter:blur(var(--blur-glass));-webkit-backdrop-filter:blur(var(--blur-glass));border:1px solid var(--border-subtle);border-radius:var(--radius-lg);box-shadow:var(--shadow-card)}.auto-hide-cursor{cursor:none!important}*{transition:cursor .3s ease}.main-container{display:flex;flex-direction:column;width:100vw;height:100vh;padding:var(--space-4);padding-bottom:env(safe-area-inset-bottom,24px);box-sizing:border-box}.top-section{display:grid;grid-template-columns:22fr 53fr 25fr;grid-template-rows:auto 1fr;gap:var(--space-3);width:100%;flex:1;min-height:0}#live-weather-display{grid-column:1;grid-row:1}#weather-indices-container{grid-column:1;grid-row:2;padding:var(--space-4);height:100%}#live-time-display{grid-column:2;grid-row:1}#hourly-detailed-forecast{grid-column:2;grid-row:2}#weekly-forecast-overview{grid-column:3;grid-row:1 / span 2}.glass-panel{width:100%;height:100%;display:flex;flex-direction:column;overflow:hidden;position:relative;padding:var(--space-4)}#live-weather-display{padding:var(--space-4)}#live-time-display{padding:var(--space-6) var(--space-8);justify-content:center}#hourly-detailed-forecast{padding:0}#weekly-forecast-overview{padding:var(--space-4);overflow-y:auto}.app-header{display:flex;flex-direction:row;align-items:center;padding:var(--space-2) var(--space-6);gap:var(--space-4);width:100%;height:auto;flex-shrink:0;margin-bottom:var(--space-3)}.header-logo-area{display:flex;align-items:center;justify-content:center;flex-shrink:0}.school-logo{width:80px;height:80px;object-fit:contain;filter:drop-shadow(0 0 10px rgba(255,255,255,.2))}.header-title-area{display:flex;flex-direction:column;justify-content:center;align-items:flex-start}.school-name-cn{font-size:42px;font-family:var(--font-family-serif);font-weight:var(--font-weight-bold);color:var(--text-primary);line-height:1.1;letter-spacing:2px;text-shadow:0 4px 12px rgba(0,0,0,.3);margin:0}.school-name-en{font-size:18px;font-weight:var(--font-weight-medium);color:var(--text-secondary);text-transform:uppercase;letter-spacing:1px;margin:0;font-family:var(--font-family-system)}.system-branding{margin-left:auto;display:flex;flex-direction:column;align-items:flex-end;justify-content:center;border-left:1px solid rgba(255,255,255,.1);padding-left:var(--space-6)}.brand-title{font-size:28px;font-weight:var(--font-weight-bold);color:var(--school-blue-light);letter-spacing:4px;text-shadow:0 0 20px rgba(92,159,214,.4);line-height:1.2}.brand-subtitle{font-size:12px;color:var(--text-tertiary);letter-spacing:2px;font-weight:var(--font-weight-medium);opacity:.8}.live-weather-main{display:flex;flex-direction:column;align-items:center;justify-content:flex-start;width:100%;height:100%}.live-weather-core{display:flex;flex-direction:row;align-items:center;justify-content:center;gap:var(--space-4);flex:1;margin-top:var(--space-4);width:100%}.live-info-group{display:flex;flex-direction:column;align-items:flex-start;justify-content:center}.live-icon-png{width:200px;height:200px;background-size:contain;background-position:center;background-repeat:no-repeat;filter:drop-shadow(0 0 40px var(--glow-white-medium));animation:floating 6s ease-in-out infinite;will-change:transform;flex-shrink:0}.live-temp{font-family:var(--font-family-system);font-size:var(--text-display-1);font-weight:var(--font-weight-bold);color:var(--text-primary);line-height:.9;letter-spacing:-4px;margin:0;text-shadow:var(--shadow-subtle)}.live-text{font-size:var(--text-2xl);font-weight:var(--font-weight-bold);letter-spacing:var(--space-2);opacity:.9;margin-left:var(--space-1);margin-top:var(--space-2)}.detail-value{color:var(--text-secondary);font-weight:var(--font-weight-bold);font-variant-numeric:tabular-nums}.temp-hot{color:var(--temp-hot)!important;text-shadow:0 0 10px rgba(var(--rgb-temp-hot),.4)}.temp-warm{color:var(--temp-warm)!important}.temp-cool{color:var(--temp-cool)!important}.temp-cold{color:var(--temp-cold)!important;text-shadow:0 0 10px rgba(var(--rgb-temp-cold),.4)}.temp-freezing{color:var(--temp-freezing)!important}.temp-neutral{color:var(--text-primary)}.festival-traditional{color:var(--color-accent-orange)!important;text-shadow:0 0 12px rgba(var(--rgb-accent-orange),.6)!important}.festival-solar-term{color:var(--color-accent-blue)!important;text-shadow:0 0 12px rgba(var(--rgb-school-blue-light),.6)!important}.festival-modern{color:var(--color-accent-cyan)!important;text-shadow:0 0 12px rgba(var(--rgb-accent-cyan),.6)!important}.festival-special{color:var(--color-accent-purple)!important;text-shadow:0 0 12px rgba(var(--rgb-accent-purple),.6)!important}.info-time{font-family:var(--font-family-system);font-size:var(--text-display-2);font-weight:var(--font-weight-bold);font-variant-numeric:tabular-nums;line-height:.9;letter-spacing:-5px;background:linear-gradient(180deg,#fff,#ffffffb3);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.info-date{font-size:var(--text-xl);color:var(--text-secondary);margin-top:var(--space-2);font-weight:var(--font-weight-bold)}.info-festival{font-size:var(--text-lg);font-weight:var(--font-weight-bold);margin-top:var(--space-2)}.info-lunar-date{font-size:var(--text-lg);color:var(--text-secondary);margin-top:var(--space-1)}.weather-indices{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-3);height:100%}.indices-item{display:flex;flex-direction:column;align-items:center;justify-content:center;background:var(--surface-glass-light);border-radius:var(--radius-md);padding:var(--space-2);border:1px solid var(--border-subtle);transition:var(--transition-normal)}.indices-item:hover{background:var(--surface-glass);border-color:var(--border-highlight);transform:translateY(-2px)}.indices-icon{font-size:var(--text-3xl);margin-bottom:var(--space-1);line-height:1}.indices-name{font-size:var(--text-base);color:var(--text-tertiary);margin-bottom:var(--space-1)}.indices-text{font-size:var(--text-xl);font-weight:var(--font-weight-bold);color:inherit;text-shadow:0 2px 4px rgba(0,0,0,.2)}#hourly-detailed-forecast{display:flex;flex-direction:column;padding:var(--space-4) 0 var(--space-10) 0;height:100%}.hourly-list-container{display:flex;flex-direction:row;overflow-x:auto;gap:var(--space-2);flex:1;width:100%;scrollbar-width:none;-ms-overflow-style:none}.hourly-list-container::-webkit-scrollbar{display:none}.hourly-bar-item{display:flex;flex-direction:column;align-items:center;justify-content:flex-end;flex:1;min-width:70px;height:100%;position:relative;padding-bottom:0}.bar-temp{font-size:var(--text-xl);font-weight:var(--font-weight-bold);color:var(--text-primary);margin-bottom:var(--space-2)}.bar-visual{width:8px;background:linear-gradient(to top,var(--color-accent-blue),var(--color-accent-cyan));border-radius:var(--radius-full);margin-bottom:var(--space-3);opacity:.8;transition:height .5s ease-out}.bar-visual.temp-hot{background:linear-gradient(to top,#ff5722,#ffab91);box-shadow:0 0 10px #ff572266}.bar-visual.temp-warm{background:linear-gradient(to top,#ffc107,#ffe082)}.bar-visual.temp-cool{background:linear-gradient(to top,#00bcd4,#80deea)}.bar-visual.temp-cold{background:linear-gradient(to top,#2196f3,#90caf9);box-shadow:0 0 10px #2196f366}.bar-visual.temp-freezing{background:linear-gradient(to top,#3f51b5,#9fa8da)}.bar-visual.temp-neutral{background:linear-gradient(to top,#9e9e9e,#eee)}.bar-icon{width:60px;height:60px;background-size:contain;background-position:center;background-repeat:no-repeat;margin-bottom:var(--space-3)}.bar-wind{display:flex;flex-direction:column;align-items:center;margin-bottom:var(--space-3);gap:var(--space-1)}.wind-arrow{width:24px;height:24px;color:var(--text-tertiary)}.wind-scale{font-size:var(--text-sm);color:var(--text-tertiary);transform:scale(1)}.bar-time{font-size:var(--text-lg);color:var(--text-secondary)}#weekly-forecast-overview{display:flex;flex-direction:column;gap:var(--space-3);height:100%;padding:var(--space-4);scrollbar-width:none;-ms-overflow-style:none}#weekly-forecast-overview::-webkit-scrollbar{display:none}.weekly-list-header{text-align:center;font-size:var(--text-lg);font-weight:var(--font-weight-bold);color:var(--text-primary);margin-bottom:var(--space-3);flex-shrink:0}.weekly-overview-item{display:grid;grid-template-columns:100px 60px 1fr;align-items:center;padding:var(--space-3) 0;background:transparent;border:none;transition:var(--transition-fast)}.weekly-date-col{display:flex;flex-direction:column;justify-content:center;align-items:flex-start}.weekly-date-col .day-name{font-size:var(--text-xl);color:var(--text-primary);font-weight:var(--font-weight-bold)}.weekly-date-col .date-text{font-size:var(--text-sm);color:var(--text-tertiary);margin-top:4px;font-weight:var(--font-weight-bold)}.weekly-icon-col{display:flex;justify-content:center;align-items:center}.weekly-icon-col .weather-icon-png{width:54px;height:54px;background-size:contain;background-position:center;background-repeat:no-repeat}.weekly-temp-range-col{display:flex;align-items:center;gap:var(--space-3);width:100%;padding-left:var(--space-2)}.range-temp{font-size:var(--text-xl);font-weight:var(--font-weight-bold);color:var(--text-primary);width:50px;text-align:right}.range-temp.max{text-align:right}.range-temp.min{text-align:left}.temp-range-track{flex:1;height:8px;background:#ffffff1a;border-radius:var(--radius-full);position:relative;margin:0 var(--space-2)}.temp-range-bar{position:absolute;top:0;height:100%;border-radius:var(--radius-full);background:linear-gradient(90deg,#ffb74d,#4fc3f7)}@keyframes floating{0%{transform:translateY(0)}50%{transform:translateY(-10px)}to{transform:translateY(0)}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInRight{0%{opacity:0;transform:translate(-15px)}to{opacity:1;transform:translate(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}@keyframes floatGentle{0%{transform:translateY(0)}50%{transform:translateY(-6px)}to{transform:translateY(0)}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.animate-in{animation-duration:var(--transition-slow, .8s);animation-fill-mode:both;animation-timing-function:cubic-bezier(.2,.8,.2,1);will-change:transform,opacity}.fade-in-up{animation-name:fadeInUp}.fade-in-right{animation-name:fadeInRight}.scale-in{animation-name:scaleIn;animation-duration:.6s}.float-gentle{animation:floatGentle 4s ease-in-out infinite}.stagger-1{animation-delay:.1s}.stagger-2{animation-delay:.2s}.stagger-3{animation-delay:.3s}.stagger-4{animation-delay:.4s}.stagger-5{animation-delay:.5s}.skeleton-loading{position:relative;overflow:hidden;background:#ffffff0d;color:transparent!important;pointer-events:none;border-radius:4px}.skeleton-loading:after{content:"";position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(90deg,#fff0,#ffffff14,#fff0);background-size:200% 100%;animation:shimmer 1.5s infinite}.skeleton-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-6);gap:var(--space-4)}.skeleton-header{width:120px;height:28px;border-radius:var(--radius-md)}.skeleton-weather-core{display:flex;align-items:center;gap:var(--space-6)}.skeleton-icon{width:100px;height:100px;border-radius:var(--radius-lg)}.skeleton-info{display:flex;flex-direction:column;gap:var(--space-3)}.skeleton-temp{width:80px;height:48px;border-radius:var(--radius-md)}.skeleton-text{width:60px;height:24px;border-radius:var(--radius-md)}.skeleton-message{color:var(--text-tertiary);font-size:var(--text-sm);margin-top:var(--space-2)}.skeleton-hourly-list{display:flex;gap:var(--space-3);overflow:hidden}.skeleton-hourly-item{width:60px;height:160px;border-radius:var(--radius-md);flex-shrink:0}.skeleton-weekly-item{width:100%;height:54px;border-radius:var(--radius-md);margin-bottom:var(--space-2)}.skeleton-indices-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-3)}.skeleton-indices-item{height:80px;border-radius:var(--radius-md)}
