*{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:#f5f5f5;min-height:100vh;overflow:hidden}.app{height:100vh;display:flex;flex-direction:column;background-size:cover;background-position:center;background-color:#f5f5f5}.header{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:16px 16px 20px;background:#fff;border-bottom:1px solid #e2e8f0;flex-shrink:0;flex-wrap:wrap}.header-left{display:flex;gap:12px}.calendar-name-btn{padding:12px 20px;border:2px solid #e2e8f0;border-radius:16px;background:#fff;font-size:18px;font-weight:600;color:#1e293b;cursor:pointer;transition:all .2s;min-width:150px;text-align:center;box-shadow:0 2px 4px #0000000d}.calendar-name-btn:hover{border-color:#3b82f6;background:#eff6ff}.modal-content-wide{max-width:500px}.person-menu-modal{position:fixed;padding:8px 0;min-width:160px;width:fit-content;background:#fff;border-radius:12px;box-shadow:0 4px 20px #00000026;border:1px solid #e2e8f0;z-index:101;margin:0;transform:translate(-50%)}.person-menu-wrapper{pointer-events:auto}.menu-item{display:flex;align-items:center;gap:12px;padding:14px 20px;border:none;background:transparent;font-size:16px;cursor:pointer;text-align:left;color:#1e293b;white-space:nowrap}.menu-item:hover{background:#f1f5f9}.menu-item span:first-child{font-size:18px;width:24px;text-align:center}.menu-item-danger{color:#dc2626}.menu-item-danger:hover{background:#fee2e2}.calendars-list{margin:16px 0}.calendar-list-item{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;border:1px solid #e2e8f0;border-radius:8px;margin-bottom:8px;background:#fff;position:relative}.calendar-list-item.active{border-color:#3b82f6;background:#eff6ff}.calendar-list-item.deleted{opacity:.6;background:#f8fafc}.calendar-list-item.deleted .calendar-list-name{text-decoration:line-through;color:#94a3b8}.calendar-list-actions{display:flex;gap:8px;position:absolute;right:12px;z-index:10}.calendar-list-name{font-size:16px;cursor:pointer}.calendar-list-name:hover{color:#3b82f6}.calendar-edit-name{display:flex;gap:8px;margin:16px 0}.calendar-edit-name input{flex:1;padding:10px 14px;border:1px solid #ddd;border-radius:8px;font-size:16px}.btn-delete{color:#dc2626}.btn-delete:hover{background:#fee2e2}.icon-btn-small{width:44px;height:44px;border:2px solid #e2e8f0;border-radius:8px;background:#fff;font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center;pointer-events:auto}.icon-btn-small:hover{background:#eff6ff;border-color:#3b82f6}.icon-btn{width:56px;height:56px;border:2px solid #e2e8f0;border-radius:16px;background:#fff;color:#475569;font-size:24px;cursor:pointer;touch-action:manipulation;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 4px #0000000d}.icon-btn:hover{border-color:#3b82f6;background:#f8fafc}@media (max-width: 600px){.header{padding:12px;gap:8px}.header-left{gap:8px}.icon-btn{width:48px;height:48px;font-size:20px;border-radius:12px}.calendar-name-btn{padding:10px 16px;font-size:16px;min-width:120px;border-radius:12px}.calendar-nav{padding:12px;gap:8px;border-bottom:1px solid #e2e8f0}.calendar-nav h2{font-size:18px;min-width:150px}.nav-btn{padding:8px 12px;font-size:18px}}.person-bar{display:flex;gap:8px;padding:12px 16px;background:#f8fafc;border-bottom:1px solid #e2e8f0;overflow-x:auto;flex-shrink:0}.person-bar-item{display:flex;align-items:center;gap:8px;padding:8px 12px;background:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a;white-space:nowrap}.person-avatar{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;overflow:hidden}.avatar-img{width:100%;height:100%;object-fit:cover}.avatar-placeholder{color:#fff;font-weight:600;font-size:14px}.person-bar-name{font-size:14px;font-weight:600;color:#1e293b}.btn-color-small,.btn-avatar-small,.btn-delete-small{width:28px;height:28px;border:none;border-radius:6px;font-size:12px;cursor:pointer;display:flex;align-items:center;justify-content:center}.btn-color-small{background:#f59e0b}.btn-avatar-small{background:#e2e8f0}.btn-delete-small{background:#fee2e2;color:#dc2626}.btn-add-person-bar{padding:8px 16px;border:2px dashed #cbd5e1;border-radius:8px;background:transparent;font-size:14px;color:#64748b;cursor:pointer;white-space:nowrap}.btn-add-person-bar:hover{background:#f1f5f9;border-color:#94a3b8}.btn{padding:14px 24px;border:none;border-radius:10px;font-size:16px;cursor:pointer;touch-action:manipulation}.btn-primary{background:#2563eb;color:#fff}.btn-secondary{background:#e5e7eb;color:#374151}.btn-danger{background:#dc2626;color:#fff}.calendar-nav{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:12px 16px;background:#fff;flex-shrink:0;border-bottom:1px solid #e2e8f0;max-width:100%}.nav-btn{padding:10px 16px;border:none;background:transparent;font-size:20px;color:#64748b;cursor:pointer;touch-action:manipulation;border-radius:8px}.nav-btn:hover{background:#f1f5f9;color:#1e293b}.calendar-nav h2{flex:1;text-align:center;font-size:20px;font-weight:600;color:#1e293b;margin:0;min-width:180px}.calendar-container{flex:1;width:100%;overflow:auto;-webkit-overflow-scrolling:touch;background:#fff;position:relative}.calendar-header{display:flex;position:sticky;top:0;z-index:20;background:linear-gradient(180deg,#f8fafc,#f1f5f9);border-bottom:2px solid #cbd5e1;width:100%;min-width:max-content}.date-column-header{position:sticky;left:0;top:0;z-index:30;background:#e2e8f0;width:80px;min-width:80px;padding:10px 8px;text-align:center;font-weight:600;border-right:1px solid #d1d5db;border-bottom:2px solid #cbd5e1}.person-column-header{flex:1 0 150px;min-width:150px;padding:10px 8px;border-right:1px solid #d1d5db;border-top:3px solid;position:relative;text-align:center}.person-column-header:first-of-type{border-left:1px solid transparent}.person-column-header+.person-column-header{border-left:2px solid transparent}.person-header-content{display:flex;flex-direction:column;align-items:center;gap:4px}.person-header-wrapper{position:relative;display:flex;flex-direction:column;align-items:center;width:100%}.person-avatar-small{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;overflow:hidden}.person-avatar-small.clickable{cursor:pointer}.person-avatar-small.clickable:hover{transform:scale(1.1)}.avatar-img-small{width:100%;height:100%;object-fit:cover}.avatar-placeholder-small{color:#fff;font-weight:600;font-size:18px}.header-action-btn{position:absolute;width:40px;height:40px;border:none;border-radius:8px;font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center}.header-color-btn{top:8px;left:8px}.header-delete-btn{top:8px;right:8px;background:#fee2e2;color:#dc2626;font-size:24px}.header-delete-btn:hover{background:#fecaca}.person-name{font-weight:600;font-size:15px;color:#1e293b;display:block;word-wrap:break-word}.empty-state{text-align:center;padding:60px 20px;background:#fff}.empty-state-icon{font-size:64px;margin-bottom:16px}.empty-state h3{font-size:24px;color:#1e293b;margin-bottom:8px}.empty-state p{color:#64748b;margin-bottom:24px;font-size:16px}.calendar-grid{display:flex;flex-direction:column;gap:1px;background:#e5e7eb;width:100%;min-width:max-content}.calendar-row{display:flex;background:#fff;min-height:60px;width:100%;min-width:max-content}.calendar-row.today{background:#fef3c7}.calendar-row.is-holiday{background:#fee2e2}.date-cell{position:sticky;left:0;z-index:10;background:inherit;width:80px;min-width:80px;padding:8px;text-align:center;border-right:1px solid #d1d5db;box-shadow:2px 0 5px #0000000d}.calendar-row:not(.today):not(.is-holiday) .date-cell{background:#fff}.date-cell .day-number{display:block;font-size:20px;font-weight:600}.date-cell .day-name{display:block;font-size:12px;color:#6b7280}.date-cell .holiday{display:block;font-size:11px;color:#dc2626;margin-top:4px}.date-cell .name-day{display:none;font-size:11px;color:#6b7280;margin-top:4px}@media (min-width: 768px){.date-cell .name-day{display:block}}.person-cell{flex:1 0 150px;min-width:150px;padding:4px;border-right:1px solid #d1d5db;min-height:60px;background:linear-gradient(180deg,#fff,#fafafa);display:flex;flex-direction:column;gap:2px;position:relative}.person-cell:first-of-type{border-left:1px solid #d1d5db}.person-cell+.person-cell{border-left:2px solid}.mobile-bg-label,.activity-label{display:none}.activity{position:relative;z-index:2;padding:10px 12px;margin-bottom:4px;border-radius:6px;font-size:14px;color:#fff;display:flex;align-items:center;overflow:hidden;width:100%;box-sizing:border-box;justify-content:center;min-height:48px;cursor:pointer}.activity-title-text{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.activity-meta{position:absolute;right:0;top:0}.activity-icon{position:relative;top:2px;right:4px;font-size:12px}.activity-time{position:relative;top:2px;right:4px;margin-left:4px;font-size:10px;font-weight:600;background:#0003;padding:1px 4px;border-radius:3px}.cell-add-btn{margin-top:auto;width:100%;min-height:24px;background:transparent;border:1px dashed #cbd5e1;border-radius:4px;color:#94a3b8;font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.cell-add-btn:hover{background:#e2e8f0;border-color:#64748b;color:#334155}.activity-time-row{display:flex;align-items:center;gap:12px;margin-bottom:12px}.activity-time-row input[type=time]{padding:8px;border:1px solid #ddd;border-radius:6px;font-size:16px}.time-separator{font-weight:600;color:#64748b}.activity-icon-row{margin-bottom:12px}.activity-icon-row label{display:block;margin-bottom:8px;font-weight:600}.icon-picker{display:flex;flex-wrap:wrap;gap:6px;max-height:150px;overflow-y:auto}.icon-option{width:40px;height:40px;border:2px solid transparent;border-radius:8px;background:#f1f5f9;font-size:20px;cursor:pointer;display:flex;align-items:center;justify-content:center}.icon-option.selected{border-color:#2563eb;background:#dbeafe}.icon-clear{color:#dc2626;font-weight:700}.avatar-grid{display:grid;grid-template-columns:repeat(10,1fr);gap:8px;margin-bottom:16px;max-height:500px;overflow-y:auto;overflow-x:hidden}.avatar-grid::-webkit-scrollbar{width:10px}.avatar-grid::-webkit-scrollbar-track{background:#f1f5f9;border-radius:5px}.avatar-grid::-webkit-scrollbar-thumb{background:#94a3b8;border-radius:5px}.avatar-option{width:50px;height:50px;border:3px solid transparent;border-radius:8px;padding:4px;background:#f1f5f9;cursor:pointer;display:flex;align-items:center;justify-content:center}.avatar-option.selected{border-color:#2563eb}.avatar-none{background:#e2e8f0;font-size:24px;color:#64748b}.avatar-none-icon{line-height:1}.avatar-preview{width:100%;height:100%;object-fit:contain;object-position:center}.add-person-row{background:linear-gradient(180deg,#f8fafc,#e2e8f0);border-top:1px solid #cbd5e1;flex-shrink:0}.btn-add-row{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:16px;border:none;background:#e2e8f0;font-size:20px;color:#475569;cursor:pointer;text-align:center}.btn-add-row:hover{background:#cbd5e1}.color-picker-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:12px;margin-bottom:16px}.color-option{width:40px;height:40px;border:3px solid transparent;border-radius:8px;cursor:pointer}.color-option.selected{border-color:#1e293b}.color-picker-custom{display:flex;align-items:center;gap:12px;margin-bottom:16px}.color-picker-custom input{width:48px;height:48px;border:none;cursor:pointer}.settings-group{margin-bottom:16px}.settings-group label{display:block;margin-bottom:8px;font-weight:600;color:#1e293b}.settings-group select{width:100%;padding:12px;border:2px solid #e2e8f0;border-radius:10px;font-size:16px;background:#fff;cursor:pointer;position:relative;z-index:10}.settings-group select:focus{border-color:#3b82f6;outline:none}.settings-attribution{font-size:12px;color:#94a3b8;text-align:center;margin-top:16px;margin-bottom:16px}.modal{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:flex-start;justify-content:flex-start;z-index:100;padding:40px;overflow:auto}#qr-reader{border:none!important;padding:10px}#qr-reader video{border-radius:8px}#qr-reader__scan_region{background:#000!important}.modal-content{background:#fff;padding:20px;border-radius:12px;min-width:300px;max-width:90vw;position:relative;z-index:10;margin:auto}.modal-content h3{margin-bottom:16px;text-align:center}.modal-content input,.modal-content select{width:100%;padding:10px;margin-bottom:12px;border:1px solid #ddd;border-radius:6px;font-size:16px}.modal-actions{display:flex;gap:8px;flex-wrap:wrap;justify-content:center}.qrcode-center{display:block;margin:0 auto 16px}.url-input{width:100%;padding:8px;margin:12px 0;border:1px solid #ddd;border-radius:4px;font-size:12px}@media (max-width: 768px){.header,.calendar-header,.date-column-header{position:relative}.person-column-header{min-width:100px}.person-avatar-small{width:48px;height:48px}.person-name{font-size:13px}.modal{align-items:center;padding:20px}.modal-content{width:100%;max-width:100%;border-radius:20px 20px 0 0;max-height:90vh;overflow-y:auto;padding-bottom:30px}.color-picker-grid{grid-template-columns:repeat(4,1fr)}.color-option{width:48px;height:48px}.mobile-bg-label{display:block;position:absolute;bottom:6px;right:6px;font-size:14px;font-weight:800;opacity:.2;pointer-events:none;text-transform:uppercase;z-index:1}.activity{flex-direction:column;align-items:flex-start;padding:6px}.activity-label{display:block;font-size:9px;font-weight:700;opacity:.85;margin-bottom:2px;text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid rgba(255,255,255,.3);padding-bottom:2px;width:100%}.activity-title-text{font-size:13px;font-weight:500;width:100%}}
