*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#fafafa;--surface:#fff;--text:#1a1a2e;--text-secondary:#64748b;--border:#e2e8f0;--border-light:#f1f5f9;--primary:#3b82f6;--primary-hover:#2563eb;--danger:#ef4444;--danger-hover:#dc2626;--radius:8px;--shadow-sm:0 1px 2px #0000000d;--shadow-md:0 4px 12px #0000001a;--shadow-lg:0 8px 24px #0000001f;--font:"Inter", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;font-family:var(--font);color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:14px;line-height:1.5}body{min-height:100dvh}#root{flex-direction:column;min-height:100dvh;display:flex}button{cursor:pointer;font-family:inherit;font-size:inherit;background:0 0;border:none}input,select{font-family:inherit;font-size:inherit}.app{flex-direction:column;min-height:100dvh;display:flex}.toolbar{background:var(--surface);border-bottom:1px solid var(--border);z-index:100;justify-content:space-between;align-items:center;padding:12px 20px;display:flex;position:sticky;top:0}.logo{align-items:center;gap:10px;font-size:18px;line-height:1;display:flex}.logo-icon{flex-shrink:0}.logo-text{letter-spacing:-.5px}.logo-text-bold{color:var(--text);font-weight:700}.logo-text-light{color:var(--text-secondary);font-weight:400}.toolbar-right{align-items:center;gap:8px;display:flex}.btn-icon{border-radius:var(--radius);width:36px;height:36px;color:var(--text-secondary);justify-content:center;align-items:center;transition:all .15s;display:flex}.btn-icon:hover{background:var(--border-light);color:var(--text)}.toolbar-add-wrapper{position:relative}.toolbar-tooltip{display:none}.btn-add{border-radius:var(--radius);background:var(--primary);color:#fff;justify-content:center;align-items:center;width:36px;height:36px;transition:background .15s;display:none}.btn-add:hover{background:var(--primary-hover)}.fab-wrapper{z-index:50;position:absolute;top:-20px;left:-20px}.fab-add{background:var(--primary);color:#fff;cursor:pointer;border:none;border-radius:50%;justify-content:center;align-items:center;width:44px;height:44px;transition:background .15s,transform .15s,box-shadow .15s;display:flex;box-shadow:0 2px 8px #3b82f666}.fab-add:hover{background:var(--primary-hover);transform:scale(1.08);box-shadow:0 4px 14px #3b82f680}.fab-tooltip{white-space:nowrap;background:linear-gradient(135deg, var(--primary) 0%, #6366f1 100%);color:#fff;cursor:pointer;pointer-events:auto;letter-spacing:.1px;border-radius:10px;padding:10px 18px;font-size:13px;font-weight:600;animation:.35s cubic-bezier(.34,1.56,.64,1) tooltipIn,2s ease-in-out .4s infinite tooltipPulse;position:absolute;top:50%;left:calc(100% + 14px);transform:translateY(-50%);box-shadow:0 4px 16px #3b82f659,0 0 #3b82f600}.fab-tooltip:before{content:"";border:6px solid #0000;border-right-color:var(--primary);position:absolute;top:50%;right:100%;transform:translateY(-50%)}.fab-tooltip:after{content:"👈";margin-left:6px;font-size:14px}@keyframes tooltipIn{0%{opacity:0;transform:translateY(-50%)translate(10px)scale(.9)}to{opacity:1;transform:translateY(-50%)translate(0)scale(1)}}@keyframes tooltipPulse{0%,to{box-shadow:0 4px 16px #3b82f659,0 0 #6366f14d}50%{box-shadow:0 4px 20px #3b82f673,0 0 0 6px #6366f100}}.block-tip{z-index:60;color:#f1f5f9;white-space:nowrap;cursor:pointer;pointer-events:auto;background:linear-gradient(135deg,#1e293b 0%,#334155 100%);border-radius:10px;padding:10px 20px;font-size:13px;font-weight:500;animation:.3s cubic-bezier(.34,1.56,.64,1) blockTipIn;position:absolute;top:55px;left:50%;transform:translate(-50%);box-shadow:0 4px 20px #00000040}.block-tip:after{content:"";border:6px solid #0000;border-top-color:#334155;position:absolute;top:100%;left:50%;transform:translate(-50%)}@keyframes blockTipIn{0%{opacity:0;transform:translate(-50%)translateY(-6px)scale(.95)}to{opacity:1;transform:translate(-50%)translateY(0)scale(1)}}.schedule-outer{background:var(--bg);flex:1;justify-content:center;align-items:flex-start;padding:32px;display:flex;overflow:auto}.schedule-container{aspect-ratio:210/297;background:var(--surface);border-radius:4px;flex-direction:column;width:100%;max-width:680px;min-height:500px;padding:32px;display:flex;position:relative;box-shadow:0 1px 4px #00000014,0 8px 24px #0000000f}.schedule-grid-wrapper{background:var(--surface);border:1px solid var(--border);border-radius:4px;flex-direction:column;flex:1;min-height:0;display:flex;overflow:visible}.schedule-name-row{border-bottom:1px solid var(--border);background:var(--surface);flex-shrink:0;justify-content:space-between;align-items:center;gap:12px;padding:6px 12px;display:flex}.schedule-name-left{flex:1;min-width:0}.schedule-name-input{color:var(--text);background:0 0;border:none;outline:none;width:100%;padding:2px 0;font-family:inherit;font-size:14px;font-weight:600}.schedule-name-input::placeholder{color:var(--text-secondary);opacity:.6;font-weight:400}.schedule-name-display{color:var(--text);min-height:1.3em;font-size:14px;font-weight:600;display:block}.schedule-name-logo{flex-shrink:0;align-items:center;gap:6px;display:flex}.schedule-name-logo-text{letter-spacing:-.3px;font-size:11px;line-height:1}.schedule-name-logo-bold{color:var(--text);font-weight:700}.schedule-name-logo-light{color:var(--text-secondary);font-weight:400}.schedule-grid{grid-template-columns:52px repeat(var(--day-count), 1fr);flex:1;grid-template-rows:auto 1fr;min-height:0;display:grid}.grid-header{text-transform:uppercase;letter-spacing:.5px;color:var(--text-secondary);border-bottom:1px solid var(--border);text-align:center;background:var(--surface);padding:8px 6px;font-size:12px;font-weight:600}.grid-time-header{border-right:1px solid var(--border)}.grid-day-header{border-right:1px solid var(--border-light)}.grid-day-header:last-of-type{border-right:none}.grid-column-inner{position:absolute;inset:14px 0}.grid-time-column{border-right:1px solid var(--border);background:var(--surface);position:relative}.time-label{color:var(--text-secondary);font-variant-numeric:tabular-nums;white-space:nowrap;font-size:10px;font-weight:500;position:absolute;right:6px;transform:translateY(-50%)}.grid-day-column{border-right:1px solid var(--border-light);position:relative}.grid-day-column:last-child{border-right:none}.hour-line{border-top:1px solid var(--border);height:0;position:absolute;left:0;right:0}.half-hour-line{border-top:1px dashed var(--border-light);height:0;position:absolute;left:0;right:0}.schedule-block{-webkit-user-select:none;user-select:none;touch-action:none;z-index:1;border-radius:4px;transition:box-shadow .15s,transform .1s;position:absolute;left:1px;right:1px;overflow:hidden}.schedule-block:hover{box-shadow:var(--shadow-md);z-index:2}.schedule-block.dragging{box-shadow:var(--shadow-lg);opacity:.92;z-index:10;cursor:grabbing}.schedule-block.resizing{z-index:10}.block-content{background:linear-gradient(#0000001f 0%,#0000000a 40%,#00000014 100%);flex-direction:column;height:100%;padding:3px 6px;display:flex;position:relative;overflow:hidden}.block-title{text-overflow:ellipsis;white-space:nowrap;text-shadow:0 1px 3px #00000059;font-size:11px;font-weight:700;line-height:1.3;overflow:hidden}.block-room{opacity:.88;white-space:nowrap;text-overflow:ellipsis;text-shadow:0 1px 3px #00000040;font-size:9px;font-weight:500;overflow:hidden}.block-time{font-variant-numeric:tabular-nums;text-shadow:0 1px 3px #00000059;font-size:9px;font-weight:600}.block-resize-handle{cursor:ns-resize;background:linear-gradient(#0000,#00000014);border-radius:0 0 5px 5px;height:8px;position:absolute;bottom:0;left:0;right:0}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;background:#0006;justify-content:center;align-items:center;padding:20px;animation:.15s fadeIn;display:flex;position:fixed;inset:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal{background:var(--surface);width:100%;max-width:400px;box-shadow:var(--shadow-lg);border-radius:12px;padding:24px;animation:.2s slideUp}@keyframes slideUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.modal h2{color:var(--text);margin-bottom:20px;font-size:18px;font-weight:600}.modal label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:12px;font-size:12px;font-weight:600;display:block}.label-optional{text-transform:none;letter-spacing:0;color:var(--text-secondary);opacity:.65;font-size:10px;font-weight:400}.modal input[type=text],.modal input[type=time],.modal select{border:1px solid var(--border);border-radius:var(--radius);background:var(--bg);width:100%;color:var(--text);outline:none;margin-top:4px;padding:8px 12px;transition:border-color .15s;display:block}.modal input:focus,.modal select:focus{border-color:var(--primary)}.time-row{grid-template-columns:1fr 1fr;gap:12px;display:grid}.color-picker{flex-wrap:wrap;gap:8px;margin-bottom:20px;display:flex}.color-swatch{cursor:pointer;border:2px solid #0000;border-radius:50%;width:28px;height:28px;transition:all .15s}.color-swatch:hover{transform:scale(1.15)}.color-swatch.selected{border-color:var(--text);box-shadow:0 0 0 2px var(--surface), 0 0 0 4px var(--text)}.color-custom-btn{cursor:pointer;border:2px solid var(--border);background:conic-gradient(#f44,#ff0,#0f0,#0ff,#00f,#f0f,#f44);border-radius:50%;flex-shrink:0;width:28px;height:28px;transition:all .15s;position:relative;overflow:hidden}.color-custom-btn:hover{transform:scale(1.15)}.color-custom-btn.selected{background:var(--custom-bg,conic-gradient(#f44, #ff0, #0f0, #0ff, #00f, #f0f, #f44));border-color:var(--text);box-shadow:0 0 0 2px var(--surface), 0 0 0 4px var(--text)}.color-input-hidden{opacity:0;cursor:pointer;width:100%;height:100%;position:absolute;inset:0}.modal-actions{gap:8px;margin-top:20px;display:flex}.btn-primary{border-radius:var(--radius);background:var(--primary);color:#fff;flex:1;padding:10px 16px;font-size:14px;font-weight:600;transition:background .15s}.btn-primary:hover{background:var(--primary-hover)}.btn-secondary{border-radius:var(--radius);background:var(--bg);color:var(--text);border:1px solid var(--border);padding:10px 16px;font-size:14px;font-weight:500;transition:background .15s}.btn-secondary:hover{background:var(--border-light)}.btn-danger{border-radius:var(--radius);color:var(--danger);background:0 0;padding:8px 16px;font-size:13px;font-weight:500;transition:all .15s}.btn-danger:hover{color:var(--danger-hover);background:#ef444414}.modal-extra-actions{border-top:1px solid var(--border);flex-direction:column;align-items:flex-start;gap:8px;margin-top:16px;padding-top:16px;display:flex}.copy-row{gap:8px;width:100%;display:flex}.copy-row select{border:1px solid var(--border);border-radius:var(--radius);background:var(--bg);color:var(--text);flex:1;padding:8px 12px}.reset-description{color:var(--text-secondary);margin-bottom:16px;font-size:13px}.reset-day-list{flex-direction:column;gap:6px;display:flex}.reset-day-btn{text-align:left;border-radius:var(--radius);width:100%;color:var(--text);background:var(--bg);border:1px solid var(--border);padding:10px 14px;font-size:14px;font-weight:500;transition:background .12s;display:block}.reset-day-btn:hover{background:var(--border-light)}.reset-divider{background:var(--border);height:1px;margin:16px 0}.reset-all-btn{text-align:center;width:100%;padding:10px 14px;font-size:14px;font-weight:600}.day-toggles{flex-wrap:wrap;gap:6px;margin-bottom:16px;display:flex}.day-toggle{border:1px solid var(--border);color:var(--text-secondary);background:var(--bg);border-radius:20px;padding:6px 12px;font-size:13px;font-weight:500;transition:all .15s}.day-toggle.active{background:var(--primary);color:#fff;border-color:var(--primary)}.day-toggle:hover:not(.active){border-color:var(--text-secondary)}.settings-modal{max-width:440px}.toast{color:#fff;z-index:2000;cursor:pointer;white-space:nowrap;border-radius:10px;padding:12px 22px;font-size:14px;font-weight:500;animation:.25s cubic-bezier(.34,1.56,.64,1) toastIn;position:fixed;bottom:28px;left:50%;transform:translate(-50%);box-shadow:0 4px 20px #0000002e}.toast--success{background:#16a34a}.toast--error{background:#dc2626}@keyframes toastIn{0%{opacity:0;transform:translate(-50%)translateY(12px)scale(.95)}to{opacity:1;transform:translate(-50%)translateY(0)scale(1)}}.site-footer{border-top:1px solid var(--border);background:var(--surface);margin-top:auto;padding:40px 24px 0}.footer-inner{grid-template-columns:1.4fr 1fr 1.6fr;gap:40px;max-width:900px;margin:0 auto;padding-bottom:36px;display:grid}.footer-section{color:var(--text-secondary);flex-direction:column;gap:6px;font-size:13px;line-height:1.6;display:flex}.footer-logo{color:var(--text);align-items:center;gap:8px;margin-bottom:4px;font-size:16px;display:flex}.footer-logo strong{font-weight:700}.footer-tagline{color:var(--text-secondary);font-size:13px;line-height:1.55}.footer-heading{text-transform:uppercase;letter-spacing:.7px;color:var(--text);margin-bottom:6px;font-size:11px;font-weight:700}.footer-link{color:var(--primary);font-weight:500;text-decoration:none;transition:opacity .15s}.footer-link:hover{opacity:.75}.footer-bottom{border-top:1px solid var(--border-light);max-width:900px;color:var(--text-secondary);text-align:center;margin:0 auto;padding:16px 0;font-size:12px}@media (width<=640px){.footer-inner{grid-template-columns:1fr;gap:28px}.site-footer{padding:32px 16px 0}}@media print{.toolbar,.modal-overlay,.fab-wrapper,.site-footer{display:none!important}.schedule-outer{padding:0}.schedule-container{aspect-ratio:auto;max-width:none;box-shadow:none;padding:12px}.schedule-grid-wrapper{border:none;border-radius:0}}@media (width<=640px){.btn-add{display:flex}.fab-wrapper{display:none}.toolbar{padding:10px 12px}.logo-text{display:none}.btn-icon,.btn-add{width:32px;height:32px}.btn-icon svg,.btn-add svg{width:18px;height:18px}.toolbar-right{gap:4px}.toolbar-tooltip{white-space:nowrap;background:linear-gradient(135deg, var(--primary) 0%, #6366f1 100%);color:#fff;cursor:pointer;pointer-events:auto;letter-spacing:.1px;z-index:200;border-radius:10px;padding:10px 18px;font-size:13px;font-weight:600;animation:.35s cubic-bezier(.34,1.56,.64,1) tooltipInDown,2s ease-in-out .4s infinite tooltipPulse;display:block;position:absolute;top:calc(100% + 14px);right:0;box-shadow:0 4px 16px #3b82f659}.toolbar-tooltip:before{content:"";border:6px solid #0000;border-bottom-color:var(--primary);position:absolute;bottom:100%;right:9px}.toolbar-tooltip:after{content:"👆";margin-left:6px;font-size:14px}@keyframes tooltipInDown{0%{opacity:0;transform:translateY(-8px)scale(.9)}to{opacity:1;transform:translateY(0)scale(1)}}.schedule-outer{padding:8px;overflow-x:hidden}.schedule-container{aspect-ratio:auto;width:100%;max-width:100%;min-height:600px;box-shadow:none;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:8px}.schedule-grid-wrapper{border:none;overflow:hidden}.schedule-grid{grid-template-columns:40px repeat(var(--day-count), minmax(0, 1fr));min-width:0}.time-label{font-size:8px;right:3px}.block-title{font-size:9px}.block-time{font-size:8px}.grid-header{letter-spacing:0;padding:5px 2px;font-size:9px}.schedule-name-input{font-size:13px}.modal-overlay{align-items:flex-end;padding:12px}.modal{border-radius:16px 16px 12px 12px;max-height:90vh;padding:20px 16px;overflow-y:auto}.color-picker{gap:7px}.color-swatch,.color-custom-btn{width:26px;height:26px}.modal-actions{flex-direction:column}.btn-primary,.btn-secondary{text-align:center;width:100%}}
