*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--accent: #7c5cbf;--accent-light: #ede9f8;--accent-dark: #5a3f99;--danger: #e53935;--warn: #fb8c00;--good: #43a047;--bg: #f5f4f8;--card: #ffffff;--text: #1a1a2e;--text-sub: #6b6b80;--border: #e2e0ea;--radius: 12px;--radius-sm: 8px;--shadow: 0 2px 12px rgba(0,0,0,.08);font-family:Helvetica Neue,Arial,Hiragino Kaku Gothic ProN,Hiragino Sans,Meiryo,sans-serif}html,body,#root{height:100%}body{background:var(--bg);color:var(--text);font-size:15px;line-height:1.6;-webkit-font-smoothing:antialiased}.app{display:flex;flex-direction:column;height:100%}.top-bar{display:flex;align-items:center;justify-content:space-between;background:var(--accent);color:#fff;padding:10px 16px;height:48px;flex-shrink:0}.top-bar-title{font-weight:700;font-size:16px;letter-spacing:.04em}.btn-logout{background:#fff3;border:none;color:#fff;cursor:pointer;padding:6px;border-radius:6px;display:flex;align-items:center;transition:background .15s}.btn-logout:hover{background:#ffffff4d}.main{flex:1;overflow-y:auto}.page{max-width:600px;margin:0 auto;padding:0 0 80px}.page-header{display:flex;align-items:center;gap:8px;padding:12px 16px;background:var(--card);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:10}.page-header h1{flex:1;font-size:17px;font-weight:700}.header-actions{display:flex;gap:4px}.btn-back,.btn-icon{background:none;border:none;cursor:pointer;color:var(--accent);padding:6px;border-radius:6px;display:flex;align-items:center;transition:background .15s}.btn-back:hover,.btn-icon:hover{background:var(--accent-light)}.btn-icon.danger{color:var(--danger)}.btn-icon.danger:hover{background:#fde8e8}.login-bg{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#5a3f99,#7c5cbf 60%,#a07ee0);padding:20px}.login-card{background:var(--card);border-radius:20px;padding:40px 32px 32px;width:100%;max-width:400px;box-shadow:0 20px 60px #00000040}.login-logo{text-align:center;margin-bottom:28px;color:var(--accent)}.login-logo h1{font-size:28px;font-weight:800;letter-spacing:.1em}.login-logo p{font-size:13px;color:var(--text-sub);margin-top:2px}.login-form h2{font-size:18px;font-weight:700;margin-bottom:12px}.hint{font-size:12px;color:var(--text-sub);background:var(--accent-light);border-radius:var(--radius-sm);padding:8px 12px;margin-bottom:16px;line-height:1.5}.security-note{margin-top:20px;font-size:12px;color:var(--text-sub);text-align:center;line-height:1.5}.form{padding:20px 16px;display:flex;flex-direction:column;gap:16px}.login-form{display:flex;flex-direction:column;gap:16px}.field{display:flex;flex-direction:column;gap:4px}.field label{font-size:13px;font-weight:600;color:var(--text-sub)}.field input,.field select,.field textarea{border:1.5px solid var(--border);border-radius:var(--radius-sm);padding:10px 12px;font-size:15px;font-family:inherit;color:var(--text);background:#fff;transition:border-color .15s;width:100%}.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--accent)}.field-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}.input-wrap{position:relative;display:flex;align-items:center}.input-wrap input{padding-left:36px;padding-right:40px}.input-icon{position:absolute;left:10px;color:var(--text-sub);pointer-events:none}.eye-btn{position:absolute;right:8px;background:none;border:none;color:var(--text-sub);cursor:pointer;padding:4px;display:flex;align-items:center}.btn-primary{background:var(--accent);color:#fff;border:none;border-radius:var(--radius-sm);padding:12px 20px;font-size:15px;font-weight:700;cursor:pointer;transition:background .15s,transform .1s;width:100%}.btn-primary:hover{background:var(--accent-dark)}.btn-primary:active{transform:scale(.98)}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.btn-sm{display:flex;align-items:center;gap:4px;background:var(--accent-light);color:var(--accent);border:none;border-radius:6px;padding:6px 12px;font-size:13px;font-weight:600;cursor:pointer;transition:background .15s}.btn-sm:hover{background:#d8d0f5}.search-bar{position:relative;padding:12px 16px;background:var(--card);border-bottom:1px solid var(--border)}.search-bar input{width:100%;padding:10px 12px 10px 36px;border:1.5px solid var(--border);border-radius:20px;font-size:14px;background:var(--bg)}.search-bar input:focus{outline:none;border-color:var(--accent);background:#fff}.search-icon{position:absolute;left:28px;top:50%;transform:translateY(-50%);color:var(--text-sub);pointer-events:none}.card-list{list-style:none;padding:12px 16px;display:flex;flex-direction:column;gap:8px}.card-item{display:flex;align-items:center;gap:12px;background:var(--card);border-radius:var(--radius);padding:14px 12px;cursor:pointer;box-shadow:var(--shadow);border:1px solid var(--border);transition:transform .12s,box-shadow .12s}.card-item:hover{transform:translateY(-1px);box-shadow:0 4px 16px #0000001f}.card-item:active{transform:scale(.98)}.card-avatar{width:44px;height:44px;border-radius:50%;background:var(--accent-light);color:var(--accent);font-weight:700;font-size:18px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.card-avatar.pet{background:#fff3e0;color:#e65100}.card-body{flex:1;min-width:0}.card-name{font-weight:600;font-size:15px}.card-sub{font-size:13px;color:var(--text-sub)}.card-meta{display:flex;gap:12px;margin-top:2px;font-size:12px;color:var(--text-sub)}.card-meta span{display:flex;align-items:center;gap:3px}.card-chevron{color:var(--text-sub);flex-shrink:0}.card-chevron.flip{transform:rotate(180deg)}.pet-thumb{width:44px;height:44px;border-radius:50%;object-fit:cover;flex-shrink:0}.detail-card{margin:16px;background:var(--card);border-radius:var(--radius);padding:24px 20px;box-shadow:var(--shadow);text-align:center}.detail-avatar{width:64px;height:64px;border-radius:50%;background:var(--accent-light);color:var(--accent);font-weight:700;font-size:28px;display:flex;align-items:center;justify-content:center;margin:0 auto 12px}.detail-avatar.large{width:80px;height:80px;font-size:34px}.detail-avatar.pet{background:#fff3e0;color:#e65100}.pet-photo{width:100px;height:100px;border-radius:50%;object-fit:cover;margin:0 auto 12px;display:block;border:3px solid var(--accent-light)}.detail-name{font-size:22px;font-weight:800;margin-bottom:4px}.detail-sub{font-size:13px;color:var(--text-sub);margin-bottom:12px}.pet-badges{display:flex;gap:6px;flex-wrap:wrap;justify-content:center;margin-bottom:16px}.badge{background:var(--accent-light);color:var(--accent);padding:3px 10px;border-radius:20px;font-size:12px;font-weight:600}.detail-fields{text-align:left;display:flex;flex-direction:column;gap:10px;margin-top:16px}.detail-field{display:flex;align-items:flex-start;gap:8px;font-size:14px;color:var(--text);padding:8px 0;border-top:1px solid var(--border)}.detail-field svg{color:var(--text-sub);margin-top:2px;flex-shrink:0}.detail-field.alert{color:var(--danger)}.detail-field.alert svg{color:var(--danger)}.detail-field.notes{flex-direction:column;gap:4px}.notes-label{font-size:12px;font-weight:600;color:var(--text-sub)}.detail-field.notes p{font-size:14px;line-height:1.6;white-space:pre-wrap}.detail-row{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-top:1px solid var(--border);font-size:14px}.row-label{color:var(--text-sub)}.row-value{font-weight:600}.tag-wrap{display:flex;gap:6px;flex-wrap:wrap}.tag{background:var(--accent-light);color:var(--accent);padding:3px 10px;border-radius:20px;font-size:12px;font-weight:600}.section{margin:0 16px 16px}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}.section-header h3{display:flex;align-items:center;gap:6px;font-size:15px;font-weight:700;color:var(--text)}.empty-sm{font-size:13px;color:var(--text-sub);text-align:center;padding:20px 0}.record-list{list-style:none;display:flex;flex-direction:column;gap:8px}.record-item{background:var(--card);border-radius:var(--radius);padding:14px 16px;cursor:pointer;box-shadow:var(--shadow);border:1px solid var(--border);transition:transform .12s}.record-item:hover{transform:translateY(-1px)}.record-date{font-size:13px;color:var(--text-sub);margin-bottom:6px}.record-body{display:flex;align-items:center;justify-content:space-between;gap:8px}.record-services{display:flex;gap:5px;flex-wrap:wrap}.record-price{font-weight:700;color:var(--accent);font-size:14px;white-space:nowrap}.record-header-info{margin-bottom:8px}.record-date-large{font-size:24px;font-weight:800}.record-pet-name{font-size:14px;color:var(--text-sub);margin:4px 0}.condition-badge{display:inline-block;padding:3px 12px;border-radius:20px;font-size:12px;font-weight:700;margin-top:8px}.condition-good{background:#e8f5e9;color:var(--good)}.condition-normal{background:#e3f2fd;color:#1565c0}.condition-warn{background:#fff3e0;color:var(--warn)}.condition-danger{background:#fde8e8;color:var(--danger)}.photo-upload{cursor:pointer;display:flex;justify-content:center}.photo-placeholder{width:100px;height:100px;border-radius:50%;border:2px dashed var(--border);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;color:var(--text-sub);font-size:12px;transition:border-color .15s,background .15s}.photo-placeholder:hover{border-color:var(--accent);background:var(--accent-light)}.photo-preview{width:100px;height:100px;border-radius:50%;object-fit:cover;border:3px solid var(--accent-light)}.service-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:8px}.service-check{display:flex;align-items:center;gap:6px;background:var(--bg);border:1.5px solid var(--border);border-radius:8px;padding:8px 10px;cursor:pointer;font-size:13px;font-weight:500;transition:border-color .15s,background .15s}.service-check:has(input:checked){border-color:var(--accent);background:var(--accent-light);color:var(--accent);font-weight:700}.service-check input{accent-color:var(--accent)}.form-pet-name{font-size:13px;color:var(--text-sub);background:var(--accent-light);border-radius:var(--radius-sm);padding:8px 12px;font-weight:600}.empty{display:flex;flex-direction:column;align-items:center;gap:16px;padding:60px 20px;color:var(--text-sub)}.empty p{font-size:14px}.empty .btn-primary{width:auto;padding:10px 24px}.error{background:#fde8e8;color:var(--danger);border-radius:6px;padding:8px 12px;font-size:13px}.top-bar-actions{display:flex;gap:4px;align-items:center}.sync-info-box{display:flex;gap:12px;align-items:flex-start;background:var(--accent-light);border-radius:var(--radius);padding:14px;color:var(--accent)}.sync-info-title{font-weight:700;font-size:14px;margin-bottom:4px}.sync-info-desc{font-size:13px;color:var(--text-sub);line-height:1.5}.sync-status{display:flex;align-items:center;gap:6px;padding:8px 12px;border-radius:8px;font-size:13px;font-weight:600}.sync-status.ok{background:#e8f5e9;color:var(--good)}.sync-status.error{background:#fde8e8;color:var(--danger)}.btn-secondary{background:var(--accent-light);color:var(--accent);border:none;border-radius:var(--radius-sm);padding:12px 20px;font-size:15px;font-weight:700;cursor:pointer;width:100%;transition:background .15s}.btn-secondary:hover{background:#d8d0f5}.btn-secondary:disabled{opacity:.5;cursor:not-allowed}.btn-danger-outline{background:none;color:var(--danger);border:1.5px solid var(--danger);border-radius:var(--radius-sm);padding:10px 20px;font-size:14px;font-weight:600;cursor:pointer;width:100%;transition:background .15s}.btn-danger-outline:hover{background:#fde8e8}.sync-section{border:1.5px solid var(--accent-light);border-radius:var(--radius);padding:14px;background:#faf9ff}.sync-link-box{display:flex;flex-direction:column;gap:8px}.sync-hint{font-size:12px;color:var(--text-sub);line-height:1.5}.sync-id-row{display:flex;gap:8px;align-items:center}.sync-id-input{flex:1;border:1.5px solid var(--border);border-radius:8px;padding:8px 10px;font-size:14px}.sync-id-input:focus{outline:none;border-color:var(--accent)}.sync-linked{font-size:13px;color:var(--text-sub);margin-bottom:8px}.sync-unlink{background:none;border:none;color:var(--danger);font-size:12px;cursor:pointer;margin-left:8px;text-decoration:underline}.sync-push{margin-top:12px;padding-top:12px;border-top:1px solid var(--border);display:flex;flex-direction:column;gap:6px}.sync-msg{font-size:13px;color:var(--text-sub)}.appointment-list{list-style:none;display:flex;flex-direction:column;gap:6px}.appointment-item{display:flex;align-items:center;gap:8px;font-size:13px;padding:6px 0;border-bottom:1px solid var(--border)}.appt-date{color:var(--text-sub);width:90px;flex-shrink:0}.appt-service{flex:1;font-weight:600}.appt-status{font-size:11px;font-weight:700;padding:2px 8px;border-radius:10px}.status-scheduled{background:var(--accent-light);color:var(--accent)}.status-completed{background:#e8f5e9;color:var(--good)}.status-cancelled{background:#f5f5f5;color:var(--text-sub)}.status-no-show{background:#fff3e0;color:var(--warn)}.cal-toolbar{display:flex;align-items:center;justify-content:space-between;padding:10px 16px;background:var(--card);border-bottom:1px solid var(--border);gap:8px}.cal-mode-tabs{display:flex;background:var(--bg);border-radius:8px;padding:3px;gap:2px}.cal-mode-tab{background:none;border:none;border-radius:6px;padding:5px 14px;font-size:13px;font-weight:600;cursor:pointer;color:var(--text-sub);transition:background .15s,color .15s}.cal-mode-tab.active{background:var(--card);color:var(--accent);box-shadow:0 1px 4px #0000001a}.cal-nav{display:flex;align-items:center;gap:4px}.cal-nav-btn{background:none;border:none;cursor:pointer;color:var(--text-sub);padding:5px;border-radius:6px;display:flex;align-items:center;transition:background .15s}.cal-nav-btn:hover{background:var(--accent-light);color:var(--accent)}.cal-nav-today{background:none;border:1.5px solid var(--border);border-radius:6px;padding:4px 10px;font-size:12px;font-weight:600;cursor:pointer;color:var(--accent);display:flex;align-items:center;gap:4px;transition:background .15s}.cal-nav-today:hover{background:var(--accent-light)}.cal-title{text-align:center;font-size:15px;font-weight:700;padding:8px 16px;background:var(--card);border-bottom:1px solid var(--border)}.cal-body{padding:8px 12px 80px}.cal-today-badge{background:var(--accent);color:#fff;border-radius:50%;width:24px;height:24px;display:inline-flex;align-items:center;justify-content:center;font-weight:700}.cal-day-view{display:flex;flex-direction:column;gap:8px;padding-top:4px}.cal-empty{text-align:center;color:var(--text-sub);font-size:14px;padding:40px 0}.cal-week-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}.cal-week-col{background:var(--card);border-radius:var(--radius-sm);border:1px solid var(--border);min-height:120px;overflow:hidden}.cal-week-col--today{border-color:var(--accent)}.cal-week-day-header{padding:4px 4px 2px;text-align:center;border-bottom:1px solid var(--border);background:var(--bg)}.cal-week-day-label{display:block;font-size:10px;color:var(--text-sub);font-weight:600}.cal-week-day-num{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;font-size:13px;font-weight:700;cursor:pointer;border-radius:50%;transition:background .15s}.cal-week-day-num:hover{background:var(--accent-light)}.cal-week-count{display:block;font-size:10px;color:var(--accent);font-weight:700}.cal-week-events{padding:3px 2px;display:flex;flex-direction:column;gap:2px}.cal-week-event{border-radius:4px;padding:2px 4px;font-size:10px;cursor:pointer;overflow:hidden;white-space:nowrap;text-overflow:ellipsis;transition:opacity .15s}.cal-week-event:hover{opacity:.8}.cal-event-time{font-weight:700;margin-right:2px}.cal-week-event--scheduled{background:var(--accent-light);color:var(--accent)}.cal-week-event--completed{background:#e8f5e9;color:var(--good)}.cal-week-event--cancelled{background:#f5f5f5;color:var(--text-sub);text-decoration:line-through}.cal-week-event--no-show{background:#fff3e0;color:var(--warn)}.cal-month-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:2px}.cal-month-weekday{text-align:center;font-size:11px;font-weight:700;color:var(--text-sub);padding:4px 0}.cal-month-cell{background:var(--card);border-radius:var(--radius-sm);border:1px solid var(--border);min-height:72px;padding:3px 3px 4px;cursor:pointer;transition:background .12s;overflow:hidden}.cal-month-cell:hover{background:var(--accent-light)}.cal-month-cell--empty{background:transparent;border-color:transparent;cursor:default}.cal-month-cell--empty:hover{background:transparent}.cal-month-cell--today{border-color:var(--accent)}.cal-month-day-num{font-size:12px;font-weight:700;display:inline-block;margin-bottom:2px}.cal-month-event{font-size:9px;border-radius:3px;padding:1px 3px;margin-bottom:1px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;cursor:pointer}.cal-month-event--scheduled{background:var(--accent-light);color:var(--accent)}.cal-month-event--completed{background:#e8f5e9;color:var(--good)}.cal-month-event--cancelled{background:#f5f5f5;color:var(--text-sub);text-decoration:line-through}.cal-month-event--no-show{background:#fff3e0;color:var(--warn)}.cal-month-more{font-size:9px;color:var(--text-sub)}.appt-card{background:var(--card);border-radius:var(--radius);padding:12px 14px;cursor:pointer;box-shadow:var(--shadow);border-left:4px solid var(--accent);transition:transform .12s}.appt-card:hover{transform:translateY(-1px)}.appt-card--completed{border-left-color:var(--good)}.appt-card--cancelled{border-left-color:var(--text-sub);opacity:.7}.appt-card--no-show{border-left-color:var(--warn)}.appt-card-time{font-size:12px;color:var(--text-sub);display:flex;align-items:center;gap:3px;margin-bottom:3px}.appt-card-name{font-weight:700;font-size:15px}.appt-card-owner{font-weight:400;font-size:13px;color:var(--text-sub)}.appt-card-services{font-size:12px;color:var(--text-sub);margin-top:2px}.appt-status-badge{display:inline-block;font-size:11px;font-weight:700;padding:2px 8px;border-radius:10px;margin-top:6px}.appt-status-large{font-size:13px;padding:4px 14px;margin-top:8px}.appt-detail-date{font-size:20px;font-weight:800;margin-bottom:4px}.appt-detail-time{display:flex;align-items:center;gap:5px;font-size:15px;color:var(--text-sub);margin-bottom:4px}.appt-type-badge-row{margin-bottom:8px}.appt-type-badge{display:inline-flex;align-items:center;gap:5px;font-size:12px;font-weight:700;padding:3px 10px;border-radius:12px}.appt-type-badge--grooming{background:var(--accent-light);color:var(--accent)}.appt-type-badge--hotel{background:#e3f2fd;color:#1565c0}.appt-hotel-dates{margin:8px 0}.appt-hotel-date-row{display:flex;justify-content:space-between;align-items:center;padding:6px 0}.appt-hotel-label{font-size:12px;font-weight:600;color:var(--text-sub)}.appt-hotel-value{font-size:14px;font-weight:700}.appt-hotel-nights{text-align:center;font-size:12px;color:var(--text-sub);padding:2px 0}.detail-link{color:var(--accent);font-weight:700;cursor:pointer;text-decoration:underline;text-underline-offset:2px}.appt-status-actions{display:flex;flex-direction:column;gap:8px}.appt-status-btn{display:flex;align-items:center;justify-content:center;gap:6px;padding:12px;border:none;border-radius:var(--radius-sm);font-size:14px;font-weight:700;cursor:pointer;transition:opacity .15s}.appt-status-btn:hover{opacity:.85}.appt-status-btn--complete{background:#e8f5e9;color:var(--good)}.appt-status-btn--cancel{background:#fde8e8;color:var(--danger)}.appt-status-btn--noshow{background:#fff3e0;color:var(--warn)}.appt-type-tabs{display:flex;gap:8px}.appt-type-tab{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;padding:10px;border:2px solid var(--border);border-radius:var(--radius-sm);background:var(--bg);font-size:14px;font-weight:600;cursor:pointer;color:var(--text-sub);transition:border-color .15s,color .15s,background .15s}.appt-type-tab.active{border-color:var(--accent);background:var(--accent-light);color:var(--accent)}.btn-logout--active{background:#ffffff59!important}.import-toolbar{display:flex;justify-content:space-between;align-items:center;padding:10px 16px;background:var(--card);border-bottom:1px solid var(--border)}.import-count{font-size:13px;color:var(--text-sub);font-weight:600}.import-item{cursor:pointer;border:1.5px solid var(--border);transition:border-color .15s,background .15s}.import-item.selected{border-color:var(--accent);background:var(--accent-light)}.import-check{width:28px;height:28px;border-radius:50%;border:2px solid var(--border);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--accent);transition:border-color .15s}.import-check.checked{border-color:var(--accent);background:#fff}.import-footer{position:fixed;bottom:0;left:0;right:0;padding:12px 16px;background:var(--card);border-top:1px solid var(--border);max-width:600px;margin:0 auto}.import-footer .btn-primary{display:flex;align-items:center;justify-content:center;gap:6px}.import-done{display:flex;flex-direction:column;align-items:center;gap:20px;padding:80px 20px;text-align:center}.import-done h2{font-size:20px;font-weight:700}.import-done .btn-primary{width:auto;padding:12px 32px}.sync-target-box{display:flex;flex-direction:column;gap:2px;background:var(--bg);border:1.5px solid var(--border);border-radius:var(--radius-sm);padding:10px 14px}.sync-target-label{font-size:11px;font-weight:600;color:var(--text-sub)}.sync-target-url{font-size:14px;font-weight:600;color:var(--text)}
