:root{--bg-color: #fdfaf5;--card-bg: #ffffff;--primary: #5d6d3c;--primary-hover: #4a5730;--text-main: #4a4a4a;--text-sub: #8c8c8c;--accent: #d4a373;--shadow: 0 8px 30px rgba(93, 109, 60, .1);--radius: 16px}*,*: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:var(--bg-color);color:var(--text-main);min-height:100vh}.calendar-page{display:flex;flex-direction:column;min-height:100vh;background:var(--bg-color);max-width:100vw;overflow-x:hidden}.calendar-topbar{display:flex;align-items:center;background:var(--bg-color);padding:12px 16px;border-bottom:2px solid #eee;position:sticky;top:0;z-index:20}.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:32px;font-weight:700;color:var(--primary);line-height:1}.nav-btn{background:var(--card-bg);border:1px solid #ddd;border-radius:10px;width:40px;height:40px;display:flex;align-items:center;justify-content:center;font-size:16px;cursor:pointer;color:var(--primary);box-shadow:0 2px 8px #0000000d}.nav-btn:active{background:#f0f0f0}.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:var(--card-bg);border:1px solid #ddd;border-radius:10px;width:40px;height:40px;display:flex;align-items:center;justify-content:center;font-size:20px;cursor:pointer;color:var(--text-sub);box-shadow:0 2px 8px #0000000d;margin-left:12px}.photo-upload-area{padding:16px;background:var(--bg-color);border-bottom:2px solid #eee}.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:100%;border-collapse:collapse;table-layout:fixed;font-size:11px}.date-header,.date-cell,.person-header,.cell{width:12.5%}thead tr{background:#f8f8f8;border-bottom:2px solid #ccc;position:sticky;top:0;z-index:10}.date-header,.person-header{text-align:center;padding:4px 1px;font-size:10px;font-weight:700;border:1px solid #ddd}.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,.date-cell,.person-header,.date-header{padding:8px 4px;border:1px solid #ddd;vertical-align:top;cursor:pointer;position:relative;background:#fff}.cell:hover:not(.readonly){background:#f5f9ff}.cell.readonly{cursor:default;background:#fafafa}.cell.saving{opacity:.6}.cell-text{display:block;white-space:pre-wrap;word-break:break-all;font-size:11px;line-height:1.3;color:#333;padding:2px}.cell-placeholder{color:#ddd;font-size:14px}.cell-input{width:100%;border:1px solid #1a73e8;outline:none;resize:vertical;font-size:13px;font-family:inherit;background:#fff;padding:4px;line-height:1.4}.day-row.sunday .date-cell,.day-row.sunday .cell{background:#fff5f5}.day-row.saturday .date-cell,.day-row.saturday .cell{background:#f5f8ff}.day-row.holiday .date-cell,.day-row.holiday .cell{background:#fff5f5}.day-row.today{outline:2px solid #1a73e8;z-index:10}.day-row.today .date-cell{background:#e8f0fe}.photo-view-section{background:#fdfdfd;border-bottom:3px solid #eee;padding:8px}.section-label{font-size:11px;font-weight:700;color:#666;margin-bottom:6px;text-transform:uppercase;letter-spacing:.05em}.photo-container{width:100%;max-height:70vh;overflow:auto;border:1px solid #ddd;border-radius:4px;background:#fff;display:flex;justify-content:center}.handwritten-photo{max-width:100%;height:auto;display:block;object-fit:contain}.calendar-scroll-wrapper:before{content:"📝 デジタル予定表（追記用）";display:block;padding:8px;background:#f8f9fa;font-size:11px;font-weight:700;color:#666;border-bottom:1px solid #eee}.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:var(--bg-color);background-image:radial-gradient(circle at 10% 20%,rgba(93,109,60,.03) 0%,transparent 20%),radial-gradient(circle at 90% 80%,rgba(212,163,115,.05) 0%,transparent 25%)}.login-card{background:var(--card-bg);border-radius:var(--radius);padding:40px 32px;width:100%;max-width:340px;box-shadow:var(--shadow);border:1px solid rgba(93,109,60,.05);text-align:center}.login-header-icon{font-size:40px;margin-bottom:16px;display:block}.login-title{font-size:24px;margin-bottom:24px;color:var(--text-main);font-weight:700;letter-spacing:.1em}.login-form{display:flex;flex-direction:column;gap:16px}.login-input{width:100%;padding:14px 16px;font-size:18px;border:2px solid #eee;border-radius:12px;outline:none;background:#fafafa;transition:all .2s;text-align:center;letter-spacing:.2em}.login-input:focus{border-color:var(--primary);background:#fff;box-shadow:0 0 0 4px #5d6d3c1a}.login-btn{width:100%;padding:14px;background:var(--primary);color:#fff;border:none;border-radius:12px;font-size:16px;font-weight:700;cursor:pointer;box-shadow:0 4px 12px #5d6d3c33;transition:all .2s}.login-btn:active{transform:translateY(2px);box-shadow:0 2px 4px #5d6d3c33}.login-btn:disabled{opacity:.5;background:#ccc}.login-error{color:#c0392b;font-size:13px;margin-top:12px}.ocr-btn{width:100%;padding:14px;background:var(--primary);color:#fff;border:none;border-radius:12px;font-size:15px;font-weight:700;cursor:pointer;box-shadow:0 4px 15px #5d6d3c33}.ocr-btn:active{background:var(--primary-hover)}.btn-confirm{background:var(--primary);border-radius:8px}.btn-cancel{background:#ddd;color:var(--text-main);border-radius:8px}.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}
