:root{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;--code-bg:#f4f3ec;--accent:#aa3bff;--accent-bg:#aa3bff1a;--accent-border:#aa3bff80;--social-bg:#f4f3ec80;--shadow:#0000001a 0 10px 15px -3px, #0000000d 0 4px 6px -2px;--sans:system-ui, "Segoe UI", Roboto, sans-serif;--heading:system-ui, "Segoe UI", Roboto, sans-serif;--mono:ui-monospace, Consolas, monospace;font:18px/145% var(--sans);letter-spacing:.18px;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light dark;color:var(--text);background:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}@media (prefers-color-scheme:dark){:root{--lightningcss-light: ;--lightningcss-dark:initial}}@media (width<=1024px){:root{font-size:16px}}@media (prefers-color-scheme:dark){:root{--text:#9ca3af;--text-h:#f3f4f6;--bg:#16171d;--border:#2e303a;--code-bg:#1f2028;--accent:#c084fc;--accent-bg:#c084fc26;--accent-border:#c084fc80;--social-bg:#2f303a80;--shadow:#0006 0 10px 15px -3px, #00000040 0 4px 6px -2px}#social .button-icon{filter:invert()brightness(2)}}body{margin:0}#root{text-align:center;border-inline:1px solid var(--border);box-sizing:border-box;flex-direction:column;width:1126px;max-width:100%;min-height:100svh;margin:0 auto;display:flex}h1,h2{font-family:var(--heading);color:var(--text-h);font-weight:500}h1{letter-spacing:-1.68px;margin:32px 0;font-size:56px}@media (width<=1024px){h1{margin:20px 0;font-size:36px}}h2{letter-spacing:-.24px;margin:0 0 8px;font-size:24px;line-height:118%}@media (width<=1024px){h2{font-size:20px}}p{margin:0}code,.counter{font-family:var(--mono);color:var(--text-h);border-radius:4px;display:inline-flex}code{background:var(--code-bg);padding:4px 8px;font-size:15px;line-height:135%}*{box-sizing:border-box;margin:0;padding:0}body{color:#5d3a4a;background-color:#fff8f9;min-height:100vh;font-family:"M PLUS Rounded 1c",sans-serif}.app{z-index:1;flex-direction:column;min-height:100vh;display:flex;position:relative}.app-header{z-index:100;background:linear-gradient(135deg,#fff0f3 0%,#fce4ec 50%,#f8e1f4 100%);border-bottom:2px solid #f48fb1;justify-content:space-between;align-items:center;height:64px;padding:0 24px;display:flex;position:sticky;top:0;box-shadow:0 2px 12px #f48fb133}.app-header h1{color:#880e4f;letter-spacing:.05em;align-items:center;gap:10px;font-family:"M PLUS Rounded 1c",sans-serif;font-size:22px;font-weight:500;display:flex}.app-header h1:before{content:"";background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='28' height='28'%3E%3Cg transform='translate(14,14)'%3E%3Cellipse cx='0' cy='-7' rx='4' ry='7' fill='%23F48FB1' opacity='0.9'/%3E%3Cellipse cx='0' cy='-7' rx='4' ry='7' fill='%23F48FB1' opacity='0.9' transform='rotate(60)'/%3E%3Cellipse cx='0' cy='-7' rx='4' ry='7' fill='%23F48FB1' opacity='0.9' transform='rotate(120)'/%3E%3Cellipse cx='0' cy='-7' rx='4' ry='7' fill='%23CE93D8' opacity='0.9' transform='rotate(180)'/%3E%3Cellipse cx='0' cy='-7' rx='4' ry='7' fill='%23CE93D8' opacity='0.9' transform='rotate(240)'/%3E%3Cellipse cx='0' cy='-7' rx='4' ry='7' fill='%23CE93D8' opacity='0.9' transform='rotate(300)'/%3E%3Ccircle cx='0' cy='0' r='5' fill='%23F9A8D4'/%3E%3C/g%3E%3C/svg%3E");background-repeat:no-repeat;background-size:contain;width:28px;height:28px;display:inline-block}.header-right{align-items:center;gap:12px;display:flex}.user-name{color:#ad1457;font-size:13px;font-weight:500}.btn-settings{cursor:pointer;color:#ad1457;background:#fff9;border:1px solid #f48fb1;border-radius:50%;justify-content:center;align-items:center;width:34px;height:34px;font-size:18px;transition:background .2s;display:flex}.btn-settings:hover{background:#ffffffe6}.loading{color:#ad1457;justify-content:center;align-items:center;height:100vh;font-family:"M PLUS Rounded 1c",sans-serif;font-size:16px;display:flex}.calendar{z-index:2;background:#fff;border-radius:24px;max-width:1100px;margin:28px auto;padding:20px 20px 24px;position:relative;box-shadow:0 4px 24px #f48fb138}.calendar-header{justify-content:center;align-items:center;gap:20px;margin-bottom:16px;display:flex}.calendar-header h2{text-align:center;color:#880e4f;letter-spacing:.06em;min-width:168px;font-family:"M PLUS Rounded 1c",sans-serif;font-size:22px;font-weight:500}.calendar-header button{cursor:pointer;color:#ad1457;background:#fffc;border:1px solid #f48fb1;border-radius:50%;justify-content:center;align-items:center;width:36px;height:36px;font-size:14px;transition:background .2s;display:flex}.calendar-header button:hover{background:#fce4ec}.btn-today{letter-spacing:.02em;white-space:nowrap;font-weight:500;writing-mode:horizontal-tb!important;border-radius:14px!important;width:auto!important;padding:0 14px!important;font-size:12px!important}.calendar-legend{color:#ad1457;background:#ffffffa6;border:1px solid #f8bbd0;border-radius:20px;flex-wrap:wrap;gap:20px;width:fit-content;margin-bottom:12px;padding:8px 12px;font-size:12px;display:flex}.legend-item{align-items:center;gap:5px;font-weight:400;display:flex}.legend-dot{border-radius:3px;width:11px;height:11px}.legend-work{background:#fce4ec;border:1px solid #f48fb1;border-radius:2px;width:11px;height:11px}.calendar-grid-wrapper{border:1.5px solid #f8bbd0;border-radius:16px;overflow:hidden;box-shadow:0 4px 20px #f48fb12e}.calendar-grid{background:#fff;grid-template-columns:repeat(7,1fr);display:grid;overflow:hidden}@keyframes slideInFromRight{0%{opacity:0;transform:translate(40px)}to{opacity:1;transform:translate(0)}}@keyframes slideInFromLeft{0%{opacity:0;transform:translate(-40px)}to{opacity:1;transform:translate(0)}}.calendar-grid.slide-from-right{animation:.28s slideInFromRight}.calendar-grid.slide-from-left{animation:.28s slideInFromLeft}.calendar-day-header{text-align:center;color:#880e4f;letter-spacing:.08em;background:linear-gradient(#fff0f3 0%,#fce4ec 100%);border-bottom:1.5px solid #f8bbd0;padding:10px 4px;font-size:12px;font-weight:500}.calendar-day{cursor:pointer;background:#fff;border-bottom:1px solid #fce4ec;border-right:1px solid #fce4ec;min-width:0;min-height:96px;padding:4px;transition:background .15s;overflow:hidden}.calendar-day:nth-child(7n){border-right:none}.calendar-day:not(.empty):hover{background-color:#fce4ec59!important}.calendar-day.empty{cursor:default;background:#fafafa}.calendar-day.today .day-number{background:#7986cb;border-radius:50%;color:#fff!important}.calendar-day.sunday .day-number{color:#c2185b}.calendar-day.saturday .day-number{color:#7b1fa2}.day-header{justify-content:space-between;align-items:center;margin-bottom:2px;display:flex}.day-number{color:#5d3a4a;flex-shrink:0;justify-content:center;align-items:center;width:26px;height:26px;font-size:13px;font-weight:500;display:flex}.holiday-name{color:#c2185b;white-space:nowrap;text-overflow:ellipsis;margin-bottom:2px;font-size:9px;font-weight:500;line-height:1.3;overflow:hidden}.work-toggle{cursor:pointer;color:#f48fb1;white-space:nowrap;background:0 0;border:1px solid #f8bbd0;border-radius:10px;padding:1px 5px;font-family:"M PLUS Rounded 1c",sans-serif;font-size:9px;line-height:1.6;transition:all .15s}.work-toggle:hover{color:#ec407a;border-color:#ec407a}.work-toggle.active{color:#fff;background:linear-gradient(135deg,#f48fb1,#ce93d8);border-color:#0000}.day-events{flex-direction:column;gap:2px;display:flex}.event-chip{color:#fff;cursor:pointer;white-space:nowrap;text-overflow:ellipsis;letter-spacing:.02em;border-radius:10px;padding:2px 7px;font-size:11px;font-weight:400;transition:opacity .15s;overflow:hidden}.event-chip:hover{opacity:.8}.event-chip.multi-day{border-radius:3px 10px 10px 3px}.form-row{gap:12px;display:flex}.form-row .form-group{flex:1}.visibility-toggle{border:1.5px solid #f8bbd0;border-radius:20px;width:fit-content;display:flex;overflow:hidden}.vis-btn{color:#ad1457;cursor:pointer;background:0 0;border:none;padding:7px 20px;font-family:"M PLUS Rounded 1c",sans-serif;font-size:13px;transition:background .2s,color .2s}.vis-btn:hover{background:#fce4ec}.vis-btn.active-public{color:#fff;background:linear-gradient(135deg,#7986cb,#9fa8da)}.vis-btn.active-private{color:#fff;background:#b0b0b0}.vis-btn.active-workday{color:#fff;background:linear-gradient(135deg,#f48fb1,#ec407a)}.vis-note{color:#ad1457;opacity:.75;margin-top:5px;font-size:11px}.toast{color:#fff;z-index:300;pointer-events:none;background:#880e4fd9;border-radius:24px;padding:10px 22px;font-size:13px;position:fixed;bottom:24px;left:50%;transform:translate(-50%)}.modal-overlay{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:200;background:#5d3a4a4d;justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;inset:0}.modal{background:linear-gradient(160deg,#fff8f9 0%,#fff 60%);border:1.5px solid #f8bbd0;border-radius:20px;width:100%;max-width:400px;padding:28px 26px;box-shadow:0 8px 32px #f48fb140}.modal h3{color:#880e4f;letter-spacing:.04em;margin-bottom:20px;font-family:"M PLUS Rounded 1c",sans-serif;font-size:17px;font-weight:500}.settings-modal{max-width:460px}.settings-modal section{border-bottom:1px dashed #f8bbd0;margin-bottom:20px;padding-bottom:20px}.settings-modal section:last-of-type{border-bottom:none}.settings-modal h4{color:#ad1457;margin-bottom:10px;font-size:13px;font-weight:500}.settings-note{color:#9e6070;margin-bottom:12px;font-size:12px;line-height:1.7}.connected-status{color:#5d3a4a;align-items:center;gap:8px;font-size:13px;display:flex}.status-dot{border-radius:50%;flex-shrink:0;width:9px;height:9px}.status-dot.connected{background:#66bb6a}.status-note{color:#b07080;font-size:11px}.form-group{margin-bottom:16px}.form-group label{color:#ad1457;letter-spacing:.03em;margin-bottom:6px;font-size:12px;font-weight:500;display:block}.form-group input,.form-group select{color:#5d3a4a;background:#ffffffe6;border:1.5px solid #f8bbd0;border-radius:10px;outline:none;width:100%;padding:10px 14px;font-family:"M PLUS Rounded 1c",sans-serif;font-size:14px;transition:border-color .2s}.form-group input:focus,.form-group select:focus{border-color:#ec407a}.modal-actions{justify-content:flex-end;gap:8px;margin-top:20px;display:flex}button{cursor:pointer;font-family:"M PLUS Rounded 1c",sans-serif}.btn-primary{color:#fff;letter-spacing:.04em;background:linear-gradient(135deg,#ec407a,#ce93d8);border:none;border-radius:20px;padding:10px 22px;font-size:13px;font-weight:500;transition:opacity .2s}.btn-primary:hover{opacity:.88}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.modal-actions>button:first-child{color:#ad1457;background:0 0;border:1.5px solid #f8bbd0;border-radius:20px;padding:10px 18px;font-size:13px;transition:background .2s}.modal-actions>button:first-child:hover{background:#fce4ec}.btn-delete{color:#c2185b;background:0 0;border:1.5px solid #f48fb1;border-radius:20px;padding:10px 18px;font-size:13px;transition:all .2s}.btn-delete:hover{background:#fce4ec}.btn-danger{color:#c2185b;background:0 0;border:1.5px solid #f48fb1;border-radius:20px;padding:8px 18px;font-size:13px;transition:all .2s}.btn-danger:hover{background:#fce4ec}.btn-google{color:#5d3a4a;background:#ffffffe6;border:1.5px solid #f8bbd0;border-radius:20px;padding:10px 18px;font-size:13px;transition:background .2s}.btn-google:hover{background:#fce4ec}.btn-google:disabled{opacity:.5;cursor:not-allowed}.btn-close{color:#ad1457;background:0 0;border:1.5px solid #f8bbd0;border-radius:20px;width:100%;margin-top:4px;padding:8px 18px;font-size:13px;transition:background .2s}.btn-close:hover{background:#fce4ec}.btn-link{color:#ec407a;cursor:pointer;font-size:inherit;background:0 0;border:none;padding:0 2px;-webkit-text-decoration:underline dotted;text-decoration:underline dotted}.login-container{justify-content:center;align-items:center;min-height:100vh;padding:16px;display:flex}.login-card{background:#ffffffeb;border:1.5px solid #f8bbd0;border-radius:24px;width:100%;max-width:400px;padding:44px 40px;box-shadow:0 8px 32px #f48fb133}.login-card h1{text-align:center;color:#880e4f;letter-spacing:.06em;margin-bottom:30px;font-family:"M PLUS Rounded 1c",sans-serif;font-size:24px;font-weight:500}.login-card p{text-align:center;color:#9e6070;margin-top:16px;font-size:13px}.login-card .btn-primary{width:100%;padding:13px;font-size:14px}.error{color:#c2185b;background:#fce4ec;border-left:3px solid #f48fb1;border-radius:10px;margin-bottom:12px;padding:9px 14px;font-size:12px}@media (width<=640px){.calendar-day{min-height:64px;padding:2px}.day-number{width:20px;height:20px;font-size:11px}.holiday-name{margin-bottom:1px;font-size:7px}.event-chip{border-radius:4px;padding-block:0;padding-inline:3px;font-size:9px;line-height:1.6}.day-events{gap:1px}.day-header{margin-bottom:1px}.calendar-legend{gap:10px;font-size:11px}.modal-overlay{-webkit-overflow-scrolling:touch;align-items:flex-start;padding:12px 12px 32px;overflow-y:auto}.modal{box-sizing:border-box;width:100%;max-width:100%;padding:18px 14px;overflow:hidden}.modal h3{margin-bottom:14px;font-size:15px}.form-group{margin-bottom:10px}.form-row{flex-direction:column;gap:0}.form-group input[type=date]{-webkit-appearance:none;box-sizing:border-box;width:100%;min-width:0;max-width:100%}.modal-actions{margin-top:14px}}
