:root{--color-bg-start: #e8f0f8;--color-bg-end: #dae4f0;--color-glass: rgba(255, 255, 255, .72);--color-glass-border: rgba(255, 255, 255, .5);--color-text: #1a1a2e;--color-text-secondary: #5a6070;--color-text-muted: #8a8fa0;--color-today: #007aff;--color-today-bg: rgba(0, 122, 255, .12);--color-red: #ff3b30;--color-red-bg: rgba(255, 59, 48, .08);--color-red-glow: rgba(255, 59, 48, .3);--shadow-glass: 0 4px 24px rgba(0, 0, 0, .06), 0 1px 4px rgba(0, 0, 0, .04), inset 0 1px 0 rgba(255, 255, 255, .6);--shadow-button: 0 2px 8px rgba(0, 0, 0, .08);--shadow-tooltip: 0 8px 32px rgba(0, 0, 0, .12), 0 2px 8px rgba(0, 0, 0, .06);--radius-xl: 24px;--radius-lg: 16px;--radius-md: 12px;--radius-sm: 8px;--font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--transition-fast: .15s ease;--transition-normal: .25s ease}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-family);background:linear-gradient(145deg,var(--color-bg-start) 0%,var(--color-bg-end) 100%);min-height:100vh;min-height:100dvh;color:var(--color-text);line-height:1.5;overflow-x:hidden}body:before{content:"";position:fixed;inset:0;background:radial-gradient(ellipse at 20% 20%,rgba(120,180,255,.15) 0%,transparent 50%),radial-gradient(ellipse at 80% 80%,rgba(180,140,255,.1) 0%,transparent 50%),radial-gradient(ellipse at 50% 50%,rgba(255,200,180,.08) 0%,transparent 50%);pointer-events:none;z-index:0}#root{position:relative;z-index:1;min-height:100vh;min-height:100dvh;display:flex;align-items:center;justify-content:center;padding:16px}.calendar-container{width:100%;max-width:420px}.calendar-card{background:var(--color-glass);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border-radius:var(--radius-xl);border:1px solid var(--color-glass-border);box-shadow:var(--shadow-glass);overflow:hidden;padding:20px}.calendar-header-row{display:flex;align-items:flex-start;gap:12px;margin-bottom:20px}.calendar-header{display:flex;justify-content:space-between;align-items:center;flex:1;gap:16px}.header-main{flex:1;min-width:0}.current-month{font-size:1.5rem;font-weight:600;letter-spacing:-.02em;color:var(--color-text)}.current-month .year{font-weight:400;color:var(--color-text-secondary)}.header-nav{display:flex;align-items:center;gap:8px}.nav-button{width:40px;height:40px;border:none;background:#fff9;border-radius:var(--radius-md);cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--color-text);transition:all var(--transition-fast);box-shadow:var(--shadow-button)}.nav-button:hover{background:#ffffffe6;transform:scale(1.05)}.nav-button:active{transform:scale(.95)}.calendar-day.pressing{transform:scale(.92);transition:transform .2s ease;background:var(--color-today-bg)}.calendar-day:active{transform:scale(.96)}.nav-button svg{width:20px;height:20px}.today-button{height:40px;padding:0 16px;border:none;background:var(--color-today);color:#fff;font-family:var(--font-family);font-size:.875rem;font-weight:500;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);box-shadow:0 2px 12px #007aff4d}.today-button:hover{background:#06d;transform:scale(1.05)}.today-button:active{transform:scale(.95)}.calendar-grid{display:flex;flex-direction:column;gap:8px}.weekday-header{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;padding-bottom:8px;border-bottom:1px solid rgba(0,0,0,.06)}.weekday{text-align:center;font-size:.75rem;font-weight:500;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-muted);padding:4px 0}.weekday:nth-child(6),.weekday:nth-child(7){color:var(--color-red);opacity:.7}.days-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;transition:opacity var(--transition-normal)}.days-grid.loading{opacity:.6}.calendar-day{aspect-ratio:1;border:none;background:transparent;border-radius:var(--radius-sm);cursor:pointer;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;font-family:var(--font-family);transition:all var(--transition-fast);position:relative}.calendar-day.empty{cursor:default}.calendar-day:not(.empty):hover{background:#0000000a}.calendar-day:not(.empty):active{transform:scale(.92)}.day-number{font-size:1rem;font-weight:400;color:var(--color-text);line-height:1}.calendar-day.other-month .day-number{color:var(--color-text-muted);opacity:.5}.calendar-day.today{background:transparent;box-shadow:inset 0 0 0 2px var(--color-today)}.calendar-day.today .day-number{color:var(--color-today);font-weight:700}.calendar-day.today:hover{background:#007aff0d;box-shadow:inset 0 0 0 2px var(--color-today)}.calendar-day.today.range-start,.calendar-day.today.range-end{background:var(--color-today);box-shadow:0 2px 12px #007aff59,inset 0 0 0 2px #fff}.calendar-day.today.range-start .day-number,.calendar-day.today.range-end .day-number{color:#fff}.calendar-day.today.in-range:not(.range-start):not(.range-end){background:var(--color-today-bg);box-shadow:inset 0 0 0 2px var(--color-today)}.calendar-day.sunday .day-number{color:var(--color-red)}.calendar-day.sunday.other-month .day-number{color:var(--color-red);opacity:.4}.calendar-day.red-day{background:var(--color-red-bg)}.calendar-day.red-day .day-number{color:var(--color-red);font-weight:500}.calendar-day.red-day.today{background:var(--color-red);box-shadow:0 2px 12px var(--color-red-glow)}.calendar-day.red-day.today .day-number{color:#fff}.holiday-dot{width:5px;height:5px;border-radius:50%}.holiday-dot.red{background:var(--color-red);box-shadow:0 0 6px var(--color-red-glow)}.holiday-dot.orange{background:#ff9500;box-shadow:0 0 6px #ff950066}.holiday-dot.yellow{background:#fc0;box-shadow:0 0 6px #fc06}.holiday-dot.flag{background:#5856d6;box-shadow:0 0 6px #5856d64d}.calendar-day.today .holiday-dot{background:#fff;box-shadow:none}.calendar-day.special-day{background:#ff95001a}.calendar-day.special-day .day-number{color:#ff9500;font-weight:500}.calendar-day.day-before-holiday:not(.special-day):not(.red-day){background:#ffcc0014}.calendar-day.day-before-holiday:not(.special-day):not(.red-day) .day-number{color:#c90}.holiday-tooltip{position:fixed;z-index:1000;background:var(--color-glass);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border-radius:var(--radius-lg);border:1px solid var(--color-glass-border);box-shadow:var(--shadow-tooltip);padding:12px 16px;min-width:180px;max-width:280px;animation:tooltipIn .2s ease-out}@keyframes tooltipIn{0%{opacity:0;transform:translateY(-8px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.tooltip-content{display:flex;align-items:center;gap:12px}.tooltip-icon{font-size:1.5rem;line-height:1}.tooltip-text{display:flex;flex-direction:column;gap:2px}.tooltip-date{font-size:.75rem;color:var(--color-text-muted)}.tooltip-name{font-size:.9375rem;font-weight:500;color:var(--color-text)}.tooltip-badge{display:inline-block;margin-top:4px;padding:2px 8px;border-radius:10px;font-size:.6875rem;font-weight:500;text-transform:uppercase;letter-spacing:.02em}.badge-red{background:#ff3b3026;color:var(--color-red)}.badge-orange{background:#ff950026;color:#e68600}.badge-yellow{background:#fc03;color:#997a00}.tooltip-description{display:block;margin-top:4px;font-size:.8125rem;color:var(--color-text-secondary);font-style:italic}.weather-widget{display:flex;align-items:center;gap:8px;padding:8px 12px;background:#fff9;border-radius:var(--radius-md);box-shadow:var(--shadow-button);transition:all var(--transition-fast)}.weather-widget:hover{background:#fffc}.weather-widget.loading{min-width:80px;justify-content:center}.weather-loading-spinner{width:16px;height:16px;border:2px solid rgba(0,0,0,.1);border-top-color:var(--color-today);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.weather-emoji{font-size:1.5rem;line-height:1}.weather-info{display:flex;flex-direction:column;gap:1px}.weather-temp{font-size:1rem;font-weight:600;color:var(--color-text);line-height:1.1}.weather-label{font-size:.625rem;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-secondary);font-weight:600;margin-bottom:-2px}.weather-desc{font-size:.6875rem;color:var(--color-text-muted);line-height:1.2}.day-weather{font-size:.9rem;line-height:1;opacity:.9;margin-top:-3px}.calendar-day.today .day-weather{opacity:1}.tooltip-weather{display:flex;align-items:center;gap:6px;margin-top:6px;padding-top:6px;border-top:1px solid rgba(0,0,0,.06)}.tooltip-weather-icon{font-size:1.25rem}.tooltip-weather-temps{display:flex;gap:8px;font-size:.8125rem}.tooltip-weather-high{color:var(--color-red);font-weight:500}.tooltip-weather-low{color:var(--color-today);font-weight:500}@media(max-width:480px){#root{padding:12px}.calendar-card{padding:16px;border-radius:var(--radius-lg)}.current-month{font-size:1.25rem}.nav-button{width:36px;height:36px}.today-button{height:36px;padding:0 12px;font-size:.8125rem}.day-number{font-size:.9375rem}}@media(min-width:768px){.calendar-container{max-width:480px}.calendar-card{padding:28px}.current-month{font-size:1.75rem}.day-number{font-size:1.125rem}}@media(max-height:500px)and (orientation:landscape){#root{padding:8px}.calendar-card{padding:12px 16px}.calendar-header{margin-bottom:12px}.weekday-header{padding-bottom:6px}.calendar-grid{gap:4px}}@supports (padding: max(0px)){#root{padding-left:max(16px,env(safe-area-inset-left));padding-right:max(16px,env(safe-area-inset-right));padding-bottom:max(16px,env(safe-area-inset-bottom))}}.range-hint{text-align:center;margin-bottom:12px;font-size:.8125rem;min-height:1.5em}.hint-default{color:var(--color-text-muted)}.hint-active{color:var(--color-today);font-weight:500;animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}.calendar-day.range-start,.calendar-day.range-end{background:var(--color-today);box-shadow:0 2px 12px #007aff59}.calendar-day.range-start .day-number,.calendar-day.range-end .day-number{color:#fff;font-weight:600}.calendar-day.range-start:hover,.calendar-day.range-end:hover{background:var(--color-today);box-shadow:0 4px 16px #007aff73}.calendar-day.in-range:not(.range-start):not(.range-end){background:var(--color-today-bg);border-radius:4px}.calendar-day.in-range:not(.range-start):not(.range-end) .day-number{color:var(--color-today)}.calendar-day.in-range.red-day:not(.range-start):not(.range-end){background:linear-gradient(135deg,var(--color-today-bg) 50%,var(--color-red-bg) 50%)}.calendar-day.range-start.red-day,.calendar-day.range-end.red-day{background:linear-gradient(135deg,var(--color-today) 60%,var(--color-red) 60%)}.calendar-day.selecting:not(.range-start):hover{background:#007aff26}.date-range-result{margin-top:16px;background:var(--color-glass);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border-radius:var(--radius-xl);border:1px solid var(--color-glass-border);box-shadow:var(--shadow-glass);padding:20px;animation:slideUp .3s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.range-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:16px;gap:12px}.range-dates{display:flex;flex-direction:column;gap:4px}.range-label{font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-muted)}.range-value{font-size:1rem;font-weight:500;color:var(--color-text)}.clear-range-button{width:32px;height:32px;border:none;background:#0000000f;border-radius:var(--radius-sm);cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--color-text-muted);transition:all var(--transition-fast);flex-shrink:0}.clear-range-button:hover{background:#0000001a;color:var(--color-text)}.clear-range-button svg{width:16px;height:16px}.range-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-bottom:16px}.stat-item{display:flex;flex-direction:column;align-items:center;gap:4px;padding:12px 8px;background:#ffffff80;border-radius:var(--radius-md)}.stat-value{font-size:1.5rem;font-weight:600;line-height:1;color:var(--color-text)}.stat-label{font-size:.6875rem;text-transform:uppercase;letter-spacing:.03em;color:var(--color-text-muted);text-align:center}.stat-item.working .stat-value{color:#34c759}.stat-item.red .stat-value{color:var(--color-red)}.stat-item.special .stat-value{color:#ff9500}.stat-item.weekend .stat-value{color:#8e8e93}.holiday-lists{padding-top:12px;border-top:1px solid rgba(0,0,0,.06);display:flex;flex-direction:column;gap:6px}.red-day-list,.special-day-list{font-size:.8125rem}.list-label{color:var(--color-text-muted);margin-right:4px}.list-items.red{color:var(--color-red);font-weight:500}.list-items.orange{color:#ff9500;font-weight:500}@media(max-width:480px){.date-range-result{padding:16px;border-radius:var(--radius-lg)}.range-stats{grid-template-columns:repeat(2,1fr)}.stat-value{font-size:1.25rem}.stat-label{font-size:.625rem}}
