:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color:#213547;background-color:#fff;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh;background-color:#f5f5f5}h1{font-size:2em;line-height:1.1;margin:0}h2{font-size:1.5em;margin:.5em 0}h3{font-size:1.2em;margin:.5em 0}button{border-radius:4px;border:1px solid #ccc;padding:.5em 1em;font-size:1em;font-weight:500;font-family:inherit;background-color:#fff;cursor:pointer;transition:all .25s}button:hover{background-color:#f0f0f0;border-color:#999}button:focus,button:focus-visible{outline:2px solid #007acc;outline-offset:2px}input[type=checkbox]{cursor:pointer}textarea{font-family:inherit;border:1px solid #ccc;border-radius:4px}textarea:focus{outline:2px solid #007acc;outline-offset:2px;border-color:#007acc}#root{max-width:100%;margin:0;padding:0;height:100vh}.app-container{display:flex;flex-direction:column;height:100vh;background-color:#f5f5f5}.app-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 2rem;background-color:#fff;border-bottom:1px solid #ddd;box-shadow:0 2px 4px #0000001a;position:relative}.app-header h1{margin:0;color:#333;font-size:1.5rem}.header-buttons{display:flex;gap:.5rem}.mobile-menu-toggle{display:none;background:none;border:1px solid #ccc;padding:.4rem .6rem;font-size:1.1rem;border-radius:6px}.header-buttons.open{display:flex}.config-button{background-color:#17a2b8;color:#fff;border:none;padding:.5rem 1rem;border-radius:4px;cursor:pointer;font-size:1rem;transition:background-color .3s}.config-button:hover{background-color:#138496}.export-button{background-color:#28a745;color:#fff;border:none;padding:.5rem 1rem;border-radius:4px;cursor:pointer;font-size:1rem;transition:background-color .3s}.export-button:hover{background-color:#218838}.import-button{background-color:#6f42c1;color:#fff;border:none;padding:.5rem 1rem;border-radius:4px;cursor:pointer;font-size:1rem;transition:background-color .3s}.import-button:hover{background-color:#5a32a3}.print-button{background-color:#4caf50;color:#fff;border:none;padding:.5rem 1rem;border-radius:4px;cursor:pointer;font-size:1rem;transition:background-color .3s}.print-button:hover{background-color:#45a049}.pet-config-panel{background-color:#f8f9fa;border-bottom:1px solid #ddd;padding:1rem 2rem}.pet-config-panel h3{margin:0 0 1rem;color:#333}.message-text-section{margin-bottom:1.5rem;padding:1rem;background-color:#fff;border:1px solid #dee2e6;border-radius:6px}.message-text-section label{display:block;margin-bottom:.5rem;color:#495057;font-size:.95rem}.message-text-input{width:100%;padding:.75rem;border:1px solid #ced4da;border-radius:4px;font-size:.9rem;font-family:inherit;resize:vertical;background-color:#fff;transition:border-color .3s;line-height:1.4}.message-text-input:focus{outline:none;border-color:#007acc;box-shadow:0 0 0 2px #007acc1a}.message-text-input::placeholder{color:#6c757d;font-style:italic}.pet-list{display:flex;gap:1rem;margin-bottom:1rem;flex-wrap:wrap}.pet-item{background-color:#e9ecef;padding:.5rem 1rem;border-radius:20px;border:1px solid #ced4da;display:flex;align-items:center;gap:.5rem}.remove-pet-button{background:none;border:none;cursor:pointer;font-size:.8rem;padding:0;opacity:.7;transition:opacity .3s}.remove-pet-button:hover{opacity:1}.add-pet-form{display:flex;gap:.5rem;align-items:center}.add-pet-form input{padding:.5rem;border:1px solid #ccc;border-radius:4px;font-size:1rem}.checklist-editor{padding:1rem;overflow-y:auto;flex:1}.left-panel,.right-panel,.checklist-editor,.main-content{min-height:0}@media (max-width: 700px){.app-header{padding:.5rem 1rem}.app-header h1{font-size:1.05rem}.mobile-menu-toggle{display:inline-flex;align-items:center;justify-content:center}.header-buttons{position:absolute;top:100%;right:.5rem;left:.5rem;background:#fff;border:1px solid #ddd;box-shadow:0 6px 18px #00000014;flex-direction:column;gap:.25rem;padding:.75rem;border-radius:8px;display:none;z-index:40}.header-buttons.open{display:flex!important;visibility:visible;opacity:1;transform:translateY(0);z-index:9999}.header-buttons{visibility:hidden;opacity:0;transform:translateY(-6px);transition:opacity .16s ease,transform .16s ease,visibility .16s}.header-buttons button{width:100%;text-align:left;padding:.6rem .75rem;font-size:.95rem}.main-content{flex-direction:column}.left-panel{border-right:none;border-bottom:1px solid #ddd}.right-panel{padding:1rem}}.checklist-editor h3{margin:0 0 1rem;color:#333;border-bottom:1px solid #ddd;padding-bottom:.5rem}.day-editor-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:.5rem;border-bottom:1px solid #ddd}.day-editor-header h3{margin:0;border:none;padding:0}.day-date-editor{display:flex;align-items:center;gap:.5rem}.day-date-editor span{font-weight:600;color:#495057}.time-period{margin-bottom:2rem;border:1px solid #e9ecef;border-radius:8px;padding:1rem;background-color:#f8f9fa}.time-period h4{margin:0 0 1rem;color:#495057;font-size:1.1rem}.pet-checklist{padding:1rem}.pet-checklist h5{margin:0 0 .5rem;color:#6c757d;font-size:1rem;font-weight:600}.add-item-button{background-color:#28a745;color:#fff;border:none;padding:.5rem 1rem;border-radius:4px;cursor:pointer;font-size:.9rem;transition:background-color .3s}.add-item-button:hover{background-color:#218838}.add-tasks-textarea{width:100%;min-height:60px;padding:.5rem;border:2px dashed #ced4da;border-radius:4px;font-size:.9rem;font-family:inherit;resize:vertical;background-color:#f8f9fa;transition:all .3s}.add-tasks-textarea:focus{outline:none;border-color:#007acc;background-color:#fff;border-style:solid}.add-tasks-textarea::placeholder{color:#6c757d;font-style:italic}.tasks-textarea{width:100%;padding:.75rem;border:1px solid #ced4da;border-radius:4px;font-size:.9rem;font-family:inherit;resize:vertical;background-color:#fff;transition:border-color .3s;line-height:1.4}.tasks-textarea:focus{outline:none;border-color:#007acc;box-shadow:0 0 0 2px #007acc1a}.tasks-textarea::placeholder{color:#6c757d;font-style:italic}.day-section{margin-bottom:2rem;border:1px solid #e9ecef;border-radius:8px;padding:1.5rem;background-color:#fff}.time-section{margin:1.5rem 0}.pet-section{margin:1rem 0;padding:1rem;background-color:#f8f9fa;border-radius:6px;border-left:4px solid #007acc}.pet-header{color:#495057;margin:0 0 .5rem;font-size:1rem;font-weight:600}.main-content{display:flex;flex:1;overflow:hidden}.left-panel{flex:1;display:flex;flex-direction:column;background-color:#fff;border-right:1px solid #ddd}.day-tabs{display:flex;padding:1rem;gap:.5rem;border-bottom:1px solid #ddd;background-color:#f9f9f9;overflow-x:auto}.day-tab-container{position:relative;display:flex;align-items:flex-start}.day-tab{padding:.5rem 1rem;border:1px solid #ddd;background-color:#fff;cursor:pointer;border-radius:4px;white-space:nowrap;transition:background-color .3s}.day-tab:hover{background-color:#f0f0f0}.day-tab.active{background-color:#007acc;color:#fff;border-color:#007acc}.remove-day-button{position:absolute;top:-5px;right:-5px;background-color:#dc3545;color:#fff;border:none;border-radius:50%;width:18px;height:18px;font-size:10px;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:.8;transition:opacity .3s}.remove-day-button:hover{opacity:1}.add-day-button{padding:.5rem 1rem;background-color:#28a745;color:#fff;border:none;border-radius:4px;cursor:pointer;white-space:nowrap;transition:background-color .3s}.add-day-button:hover{background-color:#218838}.right-panel{flex:1;padding:2rem;background-color:#fff;overflow-y:auto}.right-panel h2{margin-top:0;color:#333;border-bottom:2px solid #007acc;padding-bottom:.5rem}.rendered-content{background-color:#fff;border:1px solid #ddd;border-radius:4px;padding:1.5rem;min-height:400px;max-height:calc(100vh - 200px);overflow-y:auto}.preview-header{display:flex;align-items:center;justify-content:space-between;gap:.5rem}.preview-toggle{padding:.4rem .6rem;border-radius:6px;border:1px solid #ccc;background:#fff;cursor:pointer}.right-panel.collapsed .rendered-content{max-height:0;padding-top:0;padding-bottom:0;border:none;overflow:hidden;transition:max-height .2s ease,padding .2s ease}.preview-bar{width:100%;display:none;justify-content:center;background:transparent;margin-bottom:0}.preview-bar-toggle{width:100%;max-width:900px;padding:.75rem 1rem;border-radius:8px 8px 0 0;border:1px solid #ccc;background:linear-gradient(180deg,#fff,#f7f9fc);text-align:center;font-weight:600;cursor:pointer}.right-panel.collapsed{display:none}@media (max-width: 700px){.preview-bar{display:flex;position:fixed;left:0;right:0;bottom:0;justify-content:center;z-index:99999;padding:0 .5rem;pointer-events:none}.preview-bar-toggle{pointer-events:auto;width:calc(100% - 1rem);max-width:none;border-radius:12px 12px 0 0}.right-panel{position:fixed;left:0;right:0;bottom:0;background:#fff;border-top:1px solid #ddd;box-shadow:0 -6px 18px #00000014;max-height:70vh;transition:transform .22s ease;z-index:50}.right-panel.collapsed{display:none}.right-panel.open{transform:translateY(0)}.rendered-content{max-height:calc(70vh - 60px)}}.preview-message-text{margin-bottom:1.5rem;color:#333;text-align:left}.preview-message-text>div{margin-bottom:.5rem}.preview-message-text>div:last-child{margin-bottom:0}.day-header{color:#333;margin:0;font-size:1.3rem;border-bottom:1px solid #ccc;padding-bottom:.25rem}.date-input{padding:.5rem;border:1px solid #ccc;border-radius:4px;font-size:1rem;background-color:#fff;transition:border-color .3s}.date-input:focus{outline:none;border-color:#007acc;box-shadow:0 0 0 2px #007acc1a}.time-header{color:#666;margin:1.5rem 0 .5rem;font-size:1.1rem;font-weight:700}.checklist-item{display:flex;align-items:center;margin:.5rem 0;padding:.25rem 0}.checklist-item input[type=checkbox]{margin-right:.5rem;transform:scale(1.2)}.checklist-item label{cursor:pointer;-webkit-user-select:none;user-select:none}.checklist-item:hover{background-color:#f0f8ff;border-radius:4px;padding-left:.25rem}@media (max-width: 768px){.main-content{flex-direction:column}.left-panel{border-right:none;border-bottom:1px solid #ddd}.day-tabs{flex-wrap:wrap}.instructions-textarea{min-height:200px}}.no-pets-message{text-align:center;padding:2rem;color:#666;font-style:italic;background-color:#f9f9f9;border:2px dashed #ddd;border-radius:8px;margin:1rem 0}.no-pets-message p{margin:.5rem 0}.no-pets-message p:first-child{font-weight:700;color:#555}.stage-section{margin-bottom:1.5rem;border:1px solid #e0e0e0;border-radius:8px;overflow:hidden}.stage-header{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;background-color:#f8f9fa;border-bottom:1px solid #e0e0e0}.stage-header h3{margin:0;font-size:1.1rem;color:#333;flex:1}.stage-header input{font-size:1.1rem;font-weight:700;border:none;background:transparent;color:#333;padding:.25rem;border-radius:4px;flex:1}.stage-header input:focus{outline:2px solid #007bff;background:#fff}.stage-controls{display:flex;gap:.5rem;align-items:center}.remove-stage-button{background:#dc3545;color:#fff;border:none;padding:.25rem .5rem;border-radius:4px;cursor:pointer;font-size:.8rem;opacity:.7;transition:opacity .2s}.remove-stage-button:hover{opacity:1}.stage-tasks{padding:1rem}.add-stage-button{width:100%;padding:.375rem;background:transparent;color:#6c757d;border:1px dashed #d6d6d6;border-radius:4px;cursor:pointer;font-size:.8rem;margin:1.2rem 0;transition:all .2s ease;display:flex;align-items:center;justify-content:center;gap:.25rem;opacity:.7}.add-stage-button:hover{background:#f8f9fa;border-color:#adb5bd;color:#495057;opacity:1}@media print{.stage-header{background-color:#f0f0f0!important;-webkit-print-color-adjust:exact;print-color-adjust:exact}.stage-controls,.add-stage-button,.remove-stage-button{display:none!important}}
