*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:14px}body{font-family:Hiragino Sans,Hiragino Kaku Gothic ProN,Yu Gothic,Meiryo,sans-serif;background:#f0f0f0;color:#222;min-height:100vh}.calendar-page{display:flex;flex-direction:column;min-height:100vh;background:#fff;max-width:100vw;overflow-x:hidden}.calendar-topbar{display:flex;align-items:flex-start;background:#f8f8f8;border-bottom:2px solid #c8c8c8;position:sticky;top:0;z-index:20;padding-top:env(safe-area-inset-top,0px)}.month-header{flex:1;padding:6px 8px 4px}.month-header-main{display:flex;align-items:center;gap:8px}.month-title{display:flex;align-items:baseline;gap:4px;flex:1}.title-year{font-size:13px;color:#555;font-weight:700}.title-month{font-size:28px;font-weight:700;color:#111;line-height:1}.nav-btn{background:none;border:1px solid #ccc;border-radius:4px;padding:4px 8px;font-size:14px;cursor:pointer;color:#333;touch-action:manipulation;min-width:36px;min-height:36px}.nav-btn:active{background:#e0e0e0}.mini-cals{display:flex;gap:12px;margin-top:4px;padding-left:4px}.mini-cal-clickable{cursor:pointer}.mini-cal-clickable:active{opacity:.6}.mini-cal{font-size:9px}.mini-cal-title{font-weight:700;color:#555;margin-bottom:2px;font-size:9px}.mini-cal-grid{display:grid;grid-template-columns:repeat(7,14px);gap:1px}.mini-dow{text-align:center;color:#888;font-size:8px}.mini-day{text-align:center;font-size:9px;width:14px}.mini-day.sun{color:#c00}.mini-day.sat{color:#00c}.mini-day.empty{visibility:hidden}.mini-day.holiday{color:#c00}.settings-btn{background:none;border:none;font-size:20px;padding:8px 10px;cursor:pointer;align-self:center;color:#666;touch-action:manipulation}.settings-btn:active{color:#333}.photo-upload-area{padding:6px 8px;border-bottom:1px solid #e8e8e8}.ocr-btn{width:100%;padding:10px;background:#1a73e8;color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:700;cursor:pointer;touch-action:manipulation}.ocr-btn:active{background:#1557b0}.ocr-status{text-align:center;padding:12px;color:#555;font-size:13px}.spinner{display:inline-block;width:14px;height:14px;border:2px solid #ccc;border-top-color:#1a73e8;border-radius:50%;animation:spin .8s linear infinite;margin-right:6px;vertical-align:middle}@keyframes spin{to{transform:rotate(360deg)}}.ocr-error{color:#c0392b;font-size:12px;margin-top:6px}.ocr-review{background:#fffde7;border:1px solid #f0d800;border-radius:6px;padding:10px}.ocr-review-header h3{font-size:14px;margin-bottom:4px}.conflict-notice{font-size:11px;color:#b45309;background:#fef3c7;border:1px solid #f59e0b;border-radius:4px;padding:4px 8px;margin-bottom:8px}.ocr-entries{max-height:50vh;overflow-y:auto;margin-bottom:10px}.ocr-entry{display:flex;gap:8px;padding:6px 0;border-bottom:1px solid #e8d800;align-items:flex-start}.ocr-entry.has-conflict{background:#fff8e1;border-radius:4px;padding:6px 4px}.ocr-entry-checkbox{padding-top:4px}.ocr-entry-body{flex:1}.ocr-entry-label{display:flex;align-items:center;gap:6px;margin-bottom:4px;flex-wrap:wrap}.ocr-date{font-size:12px;font-weight:700}.ocr-person{font-size:11px;background:#1a73e8;color:#fff;padding:1px 5px;border-radius:3px}.conflict-badge{font-size:10px;background:#f59e0b;color:#fff;padding:1px 5px;border-radius:3px}.conflict-detail{font-size:10px;color:#666;margin-bottom:4px;display:flex;flex-direction:column;gap:1px}.conflict-existing{color:#888}.conflict-ocr{color:#1a73e8}.ocr-textarea{width:100%;border:1px solid #ccc;border-radius:3px;padding:3px 5px;font-size:12px;font-family:inherit;resize:vertical}.ocr-textarea:disabled{background:#f5f5f5;color:#aaa}.ocr-actions{display:flex;gap:8px}.calendar-scroll-wrapper{overflow-x:auto;-webkit-overflow-scrolling:touch;flex:1}.calendar-grid{width:100%;min-width:500px;border-collapse:collapse;table-layout:fixed;font-size:12px}.date-header,.date-cell{width:50px}.person-header,.cell{width:calc((100% - 50px) / 6)}thead tr{background:#f0f0f0;border-bottom:2px solid #aaa}.date-header{text-align:center;padding:4px 2px;font-size:11px;font-weight:700;border-right:1px solid #ccc;position:sticky;left:0;z-index:3;background:#f0f0f0}.person-header{text-align:center;padding:4px 2px;font-size:11px;font-weight:700;border-right:1px solid #ccc;border-left:1px solid #ccc}.person-header.common-col{background:#e8f5e9}.date-cell{padding:3px 2px;vertical-align:top;border:1px solid #d8d8d8;border-right:2px solid #aaa;text-align:center;background:#fafafa;white-space:nowrap;position:sticky;left:0;z-index:1}.day-number{display:block;font-size:16px;font-weight:700;line-height:1.1}.dow{display:block;font-size:10px;line-height:1.2}.dow.red{color:#c00}.dow.blue{color:#00c}.rokuyo{display:block;font-size:9px;color:#888;line-height:1.2}.cell{padding:3px 4px;border:1px solid #d8d8d8;vertical-align:top;cursor:pointer;min-height:44px;position:relative}.cell:hover:not(.readonly){background:#f5f9ff}.cell:active:not(.readonly){background:#e8f0fe}.cell.readonly{cursor:default}.cell.saving{opacity:.6}.cell-text{display:block;white-space:pre-wrap;word-break:break-all;font-size:11px;line-height:1.4}.cell-placeholder{color:#ccc;font-size:14px}.cell-input{width:100%;border:none;outline:2px solid #1a73e8;resize:none;font-size:12px;font-family:inherit;background:#fff8e1;padding:2px 3px;line-height:1.4;display:block}.day-row.sunday .date-cell,.day-row.sunday .cell{background:#fff0f0}.day-row.saturday .date-cell,.day-row.saturday .cell{background:#f0f4ff}.day-row.holiday .date-cell,.day-row.holiday .cell{background:#fff0f0}.day-row.today .date-cell{background:#e8f4fd;outline:2px solid #1a73e8;outline-offset:-2px}.day-row.past{opacity:.65}.loading-screen{text-align:center;padding:40px 20px;color:#888;font-size:14px}.login-page{display:flex;align-items:center;justify-content:center;min-height:100vh;background:#f0f4f8}.login-card{background:#fff;border-radius:12px;padding:32px 24px;width:100%;max-width:320px;box-shadow:0 4px 20px #0000001f}.login-title{text-align:center;font-size:22px;margin-bottom:24px;color:#222}.login-form{display:flex;flex-direction:column;gap:12px}.login-input{width:100%;padding:12px 14px;font-size:16px;border:1px solid #ccc;border-radius:6px;outline:none}.login-input:focus{border-color:#1a73e8;box-shadow:0 0 0 2px #c2d7fd}.login-error{color:#c0392b;font-size:13px;text-align:center}.login-btn{width:100%;padding:13px;background:#1a73e8;color:#fff;border:none;border-radius:6px;font-size:16px;font-weight:700;cursor:pointer;touch-action:manipulation}.login-btn:disabled{opacity:.6}.login-btn:active:not(:disabled){background:#1557b0}.btn-confirm{flex:1;padding:10px;background:#388e3c;color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:700;cursor:pointer;touch-action:manipulation}.btn-confirm:active{background:#2e7d32}.btn-cancel{flex:1;padding:10px;background:#888;color:#fff;border:none;border-radius:6px;font-size:14px;cursor:pointer;touch-action:manipulation}.btn-cancel:active{background:#666}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:100;padding:16px}.modal-card{background:#fff;border-radius:10px;padding:20px;width:100%;max-width:360px}.modal-title{font-size:16px;margin-bottom:16px;text-align:center}.settings-row{display:flex;align-items:center;gap:12px;margin-bottom:10px}.settings-label{width:70px;font-size:13px;color:#555;text-align:right;flex-shrink:0}.settings-input{flex:1;padding:8px 10px;border:1px solid #ccc;border-radius:5px;font-size:14px}.settings-input:focus{border-color:#1a73e8;outline:none}.modal-actions{display:flex;gap:8px;margin-top:16px}
