:root{--primary:#e8a0bf;--primary-dark:#d4789e;--primary-light:#f5d5e5;--bg:#faf5f7;--bg-card:#fff;--text:#2d2d2d;--text-secondary:#777;--border:#eee;--shadow:0 2px 8px #0000000f;--radius:12px;--nav-height:64px}*{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%;color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Hiragino Kaku Gothic ProN,Noto Sans JP,sans-serif}body{padding-bottom:var(--nav-height)}button{cursor:pointer;background:0 0;border:none;font-family:inherit}input,select,textarea{font-family:inherit;font-size:16px}a{color:inherit;text-decoration:none}.page{max-width:480px;margin:0 auto;padding:16px 16px 80px}.page-title{margin-bottom:16px;font-size:20px;font-weight:700}.card{background:var(--bg-card);border-radius:var(--radius);box-shadow:var(--shadow);margin-bottom:12px;padding:16px}.form-group{margin-bottom:16px}.form-group label{color:var(--text-secondary);margin-bottom:6px;font-size:13px;font-weight:600;display:block}.form-group input,.form-group select,.form-group textarea{border:1px solid var(--border);background:var(--bg);border-radius:8px;width:100%;padding:10px 12px;font-size:15px;transition:border-color .2s}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--primary);outline:none}.form-group textarea{resize:vertical;min-height:80px}.btn{border-radius:8px;justify-content:center;align-items:center;gap:6px;padding:10px 20px;font-size:15px;font-weight:600;transition:all .2s;display:inline-flex}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-dark)}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-secondary{background:var(--bg);color:var(--text);border:1px solid var(--border)}.btn-danger{color:#c44;background:#fee;border:1px solid #fcc}.btn-block{width:100%}.bottom-nav{height:var(--nav-height);background:var(--bg-card);border-top:1px solid var(--border);z-index:100;justify-content:space-around;align-items:center;display:flex;position:fixed;bottom:0;left:0;right:0}.bottom-nav a{color:var(--text-secondary);flex-direction:column;align-items:center;gap:2px;padding:8px 12px;font-size:11px;transition:color .2s;display:flex}.bottom-nav a.active{color:var(--primary-dark)}.bottom-nav a .nav-icon{font-size:22px}.pattern-switcher{background:var(--bg);border-radius:24px;margin-bottom:16px;padding:3px;display:flex}.pattern-switcher button{color:var(--text-secondary);border-radius:20px;flex:1;padding:8px 16px;font-size:14px;font-weight:600;transition:all .2s}.pattern-switcher button.active{background:var(--bg-card);color:var(--text);box-shadow:var(--shadow)}.routine-section{margin-bottom:20px}.routine-section h3{align-items:center;gap:6px;margin-bottom:10px;font-size:15px;display:flex}.routine-items{-webkit-overflow-scrolling:touch;gap:10px;padding-bottom:8px;display:flex;overflow-x:auto}.routine-items::-webkit-scrollbar{height:4px}.routine-items::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}.item-card{text-align:center;cursor:pointer;flex:none;width:90px;position:relative}.item-card .item-photo{object-fit:cover;background:var(--primary-light);border-radius:12px;justify-content:center;align-items:center;width:72px;height:72px;margin:0 auto 6px;font-size:32px;display:flex;overflow:hidden}.item-card .item-photo img{object-fit:cover;width:100%;height:100%}.item-card .item-name{text-overflow:ellipsis;-webkit-line-clamp:2;-webkit-box-orient:vertical;font-size:11px;font-weight:500;line-height:1.3;display:-webkit-box;overflow:hidden}.arrow{color:var(--text-secondary);flex:none;align-items:center;padding-bottom:24px;font-size:14px;display:flex}.empty-state{text-align:center;color:var(--text-secondary);padding:40px 20px}.empty-state .empty-icon{margin-bottom:12px;font-size:48px}.empty-state p{margin-bottom:16px;font-size:14px}.item-list-card{background:var(--bg-card);border-radius:var(--radius);box-shadow:var(--shadow);cursor:pointer;align-items:center;gap:12px;margin-bottom:8px;padding:12px;display:flex}.item-list-card .item-thumb{background:var(--primary-light);border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:48px;height:48px;font-size:24px;display:flex;overflow:hidden}.item-list-card .item-thumb img{object-fit:cover;width:100%;height:100%}.item-list-card .item-info{flex:1;min-width:0}.item-list-card .item-info h3{white-space:nowrap;text-overflow:ellipsis;font-size:15px;font-weight:600;overflow:hidden}.item-list-card .item-info p{color:var(--text-secondary);font-size:12px}.filter-chips{gap:6px;margin-bottom:16px;padding-bottom:4px;display:flex;overflow-x:auto}.filter-chips button{white-space:nowrap;background:var(--bg);color:var(--text-secondary);border:1px solid var(--border);border-radius:16px;padding:6px 14px;font-size:13px;transition:all .2s}.filter-chips button.active{background:var(--primary-light);color:var(--primary-dark);border-color:var(--primary)}.day-tabs{gap:4px;margin-bottom:12px;display:flex;overflow-x:auto}.day-tabs button{background:var(--bg);color:var(--text-secondary);border:1px solid #0000;border-radius:8px;flex-shrink:0;padding:8px 12px;font-size:14px;font-weight:600;transition:all .2s}.day-tabs button.active{background:var(--primary-light);color:var(--primary-dark);border-color:var(--primary)}.time-section{margin-bottom:16px}.time-section h4{align-items:center;gap:4px;margin-bottom:8px;font-size:14px;display:flex}.sortable-list{background:var(--bg);border-radius:8px;min-height:48px;padding:8px}.sortable-item{background:var(--bg-card);border-radius:8px;align-items:center;gap:8px;margin-bottom:4px;padding:8px 10px;display:flex;box-shadow:0 1px 3px #0000000d}.sortable-item .drag-handle{color:var(--text-secondary);cursor:grab}.sortable-item .remove-btn{color:#c44;padding:0 4px;font-size:18px}.add-item-btn{background:var(--bg-card);border:1px dashed var(--border);width:100%;color:var(--primary-dark);border-radius:8px;align-items:center;gap:6px;margin-top:8px;padding:10px;font-size:14px;font-weight:500;display:flex}.modal-overlay{z-index:200;background:#0006;justify-content:center;align-items:flex-end;display:flex;position:fixed;inset:0}.modal-content{background:var(--bg-card);border-radius:16px 16px 0 0;width:100%;max-width:480px;max-height:70vh;padding:20px;overflow-y:auto}.modal-content h3{margin-bottom:12px;font-size:17px}.detail-popup{padding:20px}.detail-popup .detail-header{gap:16px;margin-bottom:16px;display:flex}.detail-popup .detail-photo{background:var(--primary-light);border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:80px;height:80px;font-size:40px;display:flex;overflow:hidden}.detail-popup .detail-photo img{object-fit:cover;width:100%;height:100%}.detail-popup .detail-meta{flex:1}.detail-popup .detail-meta h2{margin-bottom:4px;font-size:18px}.detail-popup .detail-meta .brand{color:var(--text-secondary);font-size:13px}.detail-popup .detail-meta .category-badge{background:var(--primary-light);color:var(--primary-dark);border-radius:12px;margin-top:6px;padding:3px 10px;font-size:12px;font-weight:600;display:inline-block}.detail-section{margin-bottom:14px}.detail-section h4{color:var(--text-secondary);margin-bottom:4px;font-size:13px}.detail-section p{white-space:pre-wrap;font-size:14px;line-height:1.5}.weekly-grid{background:var(--bg-card);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}.weekly-header{border-bottom:1px solid var(--border);grid-template-columns:36px repeat(7,1fr);display:grid}.weekly-day-header{text-align:center;color:var(--text-secondary);padding:10px 0;font-size:13px;font-weight:600}.weekly-day-header.today{color:var(--primary-dark);background:var(--primary-light);border-radius:8px 8px 0 0}.weekly-row{border-bottom:1px solid var(--border);grid-template-columns:36px repeat(7,1fr);display:grid}.weekly-row:last-child{border-bottom:none}.weekly-label{justify-content:center;align-items:center;padding:8px 0;font-size:14px;display:flex}.weekly-cell{cursor:pointer;flex-wrap:wrap;align-content:flex-start;gap:3px;min-height:48px;padding:6px 3px;transition:background .15s;display:flex}.weekly-cell:hover{background:var(--bg)}.weekly-dot{background:var(--primary-light);cursor:pointer;border-radius:50%;justify-content:center;align-items:center;width:24px;height:24px;font-size:12px;display:flex;overflow:hidden}.weekly-dot img{object-fit:cover;width:100%;height:100%}.weekly-dot.special{background:#ffeaa7;box-shadow:0 0 0 2px #fdcb6e}.weekly-empty{text-align:center;width:100%;color:var(--border);align-self:center;font-size:12px}.weekly-legend{color:var(--text-secondary);justify-content:center;gap:16px;margin-top:12px;font-size:11px;display:flex}.template-actions{flex-wrap:wrap;gap:8px;margin-bottom:16px;display:flex}.template-actions button{background:var(--bg-card);border:1px solid var(--border);color:var(--text);border-radius:8px;padding:6px 12px;font-size:12px;font-weight:500;transition:all .2s}.template-actions button:hover{border-color:var(--primary);color:var(--primary-dark)}.day-checkboxes{flex-wrap:wrap;gap:6px;margin:12px 0;display:flex}.day-checkboxes label{background:var(--bg);cursor:pointer;border-radius:8px;align-items:center;gap:4px;padding:6px 10px;font-size:13px;transition:all .2s;display:flex}.day-checkboxes label.checked{background:var(--primary-light);color:var(--primary-dark)}.day-checkboxes input[type=checkbox]{display:none}.ocr-reader{margin-bottom:12px}.ocr-hint{color:var(--text-secondary);margin-bottom:8px;font-size:12px;line-height:1.5}.ocr-upload-btn{background:var(--primary-light);border:1px dashed var(--primary);width:100%;color:var(--primary-dark);cursor:pointer;border-radius:8px;justify-content:center;align-items:center;gap:6px;padding:10px;font-size:14px;font-weight:500;transition:all .2s;display:flex}.ocr-upload-btn:hover{background:var(--primary);color:#fff}.ocr-processing{text-align:center}.ocr-preview{object-fit:contain;border-radius:8px;width:100%;max-height:120px;margin-bottom:8px}.ocr-progress{background:var(--border);border-radius:3px;width:100%;height:6px;margin-bottom:8px;overflow:hidden}.ocr-progress-bar{background:var(--primary);border-radius:3px;height:100%;transition:width .3s}.ocr-processing p,.ocr-done p,.ocr-error p{color:var(--text-secondary);margin-bottom:8px;font-size:13px}.ocr-error p{color:#c44}
