*{box-sizing:border-box}:root{--blue: #4766ff;--purple: #7a42ff;--dark: #101935;--text: #14213d;--muted: #5f6b85;--border: #dbe2ff;--shadow: 0 10px 30px rgba(25, 35, 80, .12);--success-bg: #ecfdf3;--success-border: #b7ebc6;--success-text: #157347;--sound-bg: #f6f1ff;--sound-border: #e4d7ff;--favorite-bg: #fff7e8;--favorite-border: #ffd89a;--favorite-text: #9a6700;--danger-bg: #fff1f2;--danger-border: #fecdd3;--danger-text: #be123c}html{scroll-behavior:smooth}body{margin:0;font-family:Inter,Open Sans,Arial,sans-serif;background:radial-gradient(circle at top left,rgba(122,66,255,.18),transparent 35%),radial-gradient(circle at top right,rgba(71,102,255,.18),transparent 35%),linear-gradient(180deg,#f7f8ff,#eef2ff);color:var(--text)}button,input,select,textarea,a{font:inherit}.app-shell{min-height:100vh}.topbar{position:sticky;top:0;z-index:50;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#101935d6;border-bottom:1px solid rgba(255,255,255,.08)}.topbar-inner{max-width:1100px;margin:0 auto;padding:14px 16px;display:flex;justify-content:flex-start;align-items:center}.logo{font-family:Playfair Display,Georgia,serif;font-size:1.3rem;font-weight:700;color:#fff}.logo-accent{background:linear-gradient(90deg,#9db2ff,#c8a8ff);-webkit-background-clip:text;-webkit-text-fill-color:transparent}.container{max-width:1100px;margin:0 auto;padding:28px 16px 56px}.hero{background:linear-gradient(135deg,var(--blue),var(--purple));color:#fff;border-radius:28px;padding:42px 24px;box-shadow:var(--shadow);position:relative;overflow:hidden;margin-bottom:24px}.hero:after{content:"";position:absolute;inset:auto -40px -60px auto;width:220px;height:220px;background:#ffffff1f;border-radius:50%;filter:blur(8px)}.eyebrow{font-size:.9rem;letter-spacing:.08em;text-transform:uppercase;opacity:.9;margin-bottom:10px}.hero h1{margin:0;font-family:Playfair Display,Georgia,serif;font-size:clamp(2rem,4vw,3.6rem);line-height:1.05}.subtitle{max-width:760px;margin-top:14px;font-size:1.05rem;line-height:1.7;color:#ffffffeb}.hero-actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:22px}.hero-btn{padding:11px 16px;border-radius:999px;border:1px solid rgba(255,255,255,.28);background:#ffffff1f;color:#fff;font-weight:600;cursor:pointer}.hero-btn-light{background:#fff;color:var(--purple);border-color:#fff}.stats-card{margin-bottom:40px}.grid{display:grid;grid-template-columns:1.1fr .9fr;gap:24px;align-items:start}.card{background:#ffffffe0;border:1px solid rgba(122,66,255,.1);border-radius:24px;padding:20px;box-shadow:var(--shadow)}.card h2{margin:0 0 14px;font-family:Playfair Display,Georgia,serif;font-size:1.45rem;color:var(--dark)}.section-copy{color:var(--muted);line-height:1.6;margin-bottom:14px}.mode-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin-bottom:16px}.mode-card{text-align:left;padding:14px;border-radius:18px;border:1px solid var(--border);background:#fff;color:var(--text);box-shadow:none}.mode-card:hover{transform:translateY(-1px)}.mode-card-active{border:2px solid var(--purple);background:linear-gradient(180deg,#fff,#f6f1ff);box-shadow:0 8px 20px #7a42ff1f}.mode-title{font-weight:800;color:var(--dark);margin-bottom:4px}.mode-description{color:var(--muted);line-height:1.5;font-size:.95rem;font-weight:500}.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:14px}label{display:flex;flex-direction:column;gap:6px;color:var(--muted);font-size:.95rem;font-weight:600}select,input,textarea.situation-box{width:100%;padding:12px 14px;border-radius:14px;border:1px solid var(--border);background:#fff;color:var(--text);outline:none}textarea.situation-box{resize:vertical;min-height:110px}select:focus,input:focus,textarea.situation-box:focus{border-color:var(--purple);box-shadow:0 0 0 3px #7a42ff1f}.template-section{margin-bottom:18px;padding:14px;border-radius:18px;background:#f8f9ff;border:1px solid #e6eaff}.template-section-header{margin-bottom:12px}.template-title{margin:0 0 4px;font-size:1rem;font-weight:800;color:var(--dark)}.template-subtitle{margin:0;color:var(--muted);line-height:1.5;font-size:.92rem}.template-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.template-card{text-align:left;padding:14px;border-radius:16px;border:1px solid var(--border);background:#fff;color:var(--text);box-shadow:none}.template-card:hover{transform:translateY(-1px);border-color:#cfcfff}.template-card-active{border:2px solid var(--purple);background:linear-gradient(180deg,#fff,#f6f1ff);box-shadow:0 8px 20px #7a42ff1f}.template-card-title{font-weight:800;color:var(--dark);margin-bottom:4px}.template-card-description{color:var(--muted);line-height:1.5;font-size:.92rem;font-weight:500}.generation-toggle{margin-bottom:16px;padding:14px;border-radius:18px;background:#f8f9ff;border:1px solid #e6eaff}.generation-toggle-label{font-size:.9rem;font-weight:800;color:var(--dark);margin-bottom:10px}.generation-toggle-row{display:flex;gap:10px;flex-wrap:wrap}.generation-pill{padding:10px 14px;border-radius:999px;border:1px solid var(--border);background:#fff;color:var(--text);font-weight:700}.generation-pill-active{border:2px solid var(--purple);background:linear-gradient(180deg,#fff,#f6f1ff);color:var(--purple)}.preset-builder{margin-top:16px;padding:14px;border-radius:16px;background:#f8f9ff;border:1px solid #e6eaff}.button-row,.section-row{display:flex;gap:10px;flex-wrap:wrap;margin-top:16px;justify-content:space-between;align-items:center}.compact-row{justify-content:flex-start}.add-step-row{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end}button{padding:11px 16px;border-radius:14px;cursor:pointer;border:1px solid transparent;font-weight:700;transition:transform .15s ease,box-shadow .15s ease}button:hover{transform:translateY(-1px)}button.primary{background:linear-gradient(135deg,var(--blue),var(--purple));color:#fff;box-shadow:0 8px 20px #5a58ff38}button.secondary{background:#fff;color:var(--dark);border-color:var(--border)}button:disabled{opacity:.7;cursor:not-allowed;transform:none}.danger-button{background:var(--danger-bg);color:var(--danger-text);border:1px solid var(--danger-border)}.summary-text,.empty-text,.runner-prompt,.mini-text,.recent-situation,.recent-date{color:var(--muted);line-height:1.6}.step-list,.recent-grid{display:grid;gap:12px;margin-top:14px}.recent-grid{grid-template-columns:repeat(auto-fit,minmax(240px,1fr))}.step-card,.recent-card,.favorite-card,.preset-card{border:1px solid #e4e8ff;border-radius:18px;padding:15px;background:#fff;transition:.2s ease}.favorite-card{border-color:#ffe1ad;background:linear-gradient(180deg,#fff,#fffaf0)}.preset-card{border-color:#d7dcff;background:linear-gradient(180deg,#fff,#f6f8ff)}.active-step{border:2px solid var(--purple);background:linear-gradient(180deg,#fff,#f7f2ff);box-shadow:0 8px 22px #7a42ff1f}.drag-handle{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:12px;border:1px solid var(--border);background:#f8f9ff;color:var(--muted);cursor:grab;font-size:1rem;font-weight:700;margin-bottom:12px}.drag-handle:active{cursor:grabbing}.step-header,.recent-top{display:flex;justify-content:space-between;align-items:start;gap:12px}.step-title,.recent-title{font-weight:800;color:var(--dark);text-transform:capitalize}.step-prompt{margin-top:8px;color:var(--muted);line-height:1.6}.step-sound-chip,.badge,.recent-mode{display:inline-flex;align-items:center;width:fit-content;flex-shrink:0;font-size:.75rem;padding:5px 9px;border-radius:999px;background:#eef1ff;color:var(--blue);border:1px solid #dce3ff;font-weight:700}.step-sound-chip{margin-top:12px;background:#f6f1ff;color:var(--purple);border-color:#e4d7ff}.recent-mode{margin:10px 0 6px}.recent-meta{margin:12px 0;font-size:.9rem;font-weight:700;color:var(--blue)}.muted{opacity:.7}.edit-panel{display:grid;gap:12px}.runner-box{display:flex;flex-direction:column;gap:12px}.current-step-label{color:var(--muted);text-transform:uppercase;letter-spacing:.08em;font-size:.8rem;font-weight:700}.current-step-title{font-size:clamp(1.5rem,2vw,2rem);font-weight:800;color:var(--dark)}.timer{font-size:clamp(2.4rem,5vw,4rem);font-weight:800;color:var(--purple);line-height:1}.progress-wrap{width:100%;height:14px;background:#e9edff;border-radius:999px;overflow:hidden;border:1px solid #dbe2ff}.progress-bar{height:100%;background:linear-gradient(90deg,var(--blue),var(--purple));transition:width .4s ease}.quick-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-top:10px}.four-up{grid-template-columns:repeat(4,1fr)}.two-up{grid-template-columns:repeat(2,1fr)}.stat-box{border-radius:16px;padding:14px;background:linear-gradient(180deg,#fff,#f7f8ff);border:1px solid #e3e8ff}.stat-label{font-size:.8rem;color:var(--muted);margin-bottom:4px}.stat-value{font-size:1.1rem;font-weight:800;color:var(--dark);text-transform:capitalize}.activity-strip{margin-top:16px}.activity-title{font-size:.9rem;font-weight:700;color:var(--muted);margin-bottom:10px}.activity-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:10px}.activity-day{padding:12px 8px;border-radius:14px;background:#f8f9ff;border:1px solid #e3e8ff;text-align:center}.active-day{background:linear-gradient(180deg,#f4efff,#ebe4ff);border-color:#d9c9ff}.today-day{outline:2px solid var(--purple);outline-offset:1px}.activity-label{font-size:.8rem;color:var(--muted);margin-bottom:6px;font-weight:700}.activity-count{font-size:1rem;font-weight:800;color:var(--dark)}.recommendation-card{margin-top:16px;padding:16px;border-radius:18px;background:linear-gradient(180deg,#f7f2ff,#f2f6ff);border:1px solid #ddd8ff}.recommendation-label{font-size:.78rem;font-weight:800;text-transform:uppercase;letter-spacing:.08em;color:var(--purple);margin-bottom:6px}.recommendation-main{font-size:1rem;line-height:1.5;color:var(--dark);font-weight:600}.adaptive-card{margin-top:16px;padding:16px;border-radius:18px;background:linear-gradient(180deg,#eef7ff,#f5f2ff);border:1px solid #d7e6ff}.adaptive-main{font-size:1rem;line-height:1.6;color:var(--dark);font-weight:600}.sound-card{margin-top:8px;padding:14px;border-radius:18px;background:var(--sound-bg);border:1px solid var(--sound-border)}.sound-label{font-size:.78rem;font-weight:800;text-transform:uppercase;letter-spacing:.08em;color:var(--purple);margin-bottom:6px}.sound-title{font-size:1.05rem;font-weight:800;color:var(--dark);margin-bottom:4px}.sound-description{color:var(--muted);line-height:1.6}.audio-player{width:100%;margin-top:12px;border-radius:12px}.audio-controls{margin-top:12px;display:flex;gap:14px;align-items:center;flex-wrap:wrap}.volume-control{display:flex;align-items:center;gap:10px}.volume-control span{color:var(--muted);font-size:.95rem;font-weight:600}.volume-control input[type=range]{width:180px;height:6px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:#dbe2ff;border-radius:999px;outline:none;cursor:pointer}.volume-control input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:24px;height:24px;border-radius:50%;background:var(--purple);cursor:pointer;border:2px solid white;box-shadow:0 2px 6px #7a42ff4d}.volume-control input[type=range]::-moz-range-thumb{width:24px;height:24px;border-radius:50%;background:var(--purple);cursor:pointer;border:2px solid white;box-shadow:0 2px 6px #7a42ff4d}.completed-banner,.favorited-banner,.plan-info-banner{padding:12px 14px;border-radius:14px;font-weight:700;margin-bottom:10px}.completed-banner{background:var(--success-bg);border:1px solid var(--success-border);color:var(--success-text)}.favorited-banner{background:var(--favorite-bg);border:1px solid var(--favorite-border);color:var(--favorite-text)}.plan-info-banner{background:#eef4ff;border:1px solid #cfe0ff;color:#23408e;font-weight:600}.feedback-card{margin-top:16px;padding:20px;border-radius:18px;background:linear-gradient(180deg,#f7f2ff,#f2f6ff);border:1px solid #ddd8ff;display:flex;flex-direction:column;gap:18px}.feedback-title{font-size:1.1rem;font-weight:800;color:var(--dark)}.feedback-group{display:flex;flex-direction:column;gap:10px}.feedback-label{font-size:.82rem;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.06em}.feedback-options{display:flex;flex-wrap:wrap;gap:10px}.feedback-pill{padding:10px 18px;border-radius:999px;border:1.5px solid var(--border);background:#fff;color:var(--text);font-weight:700;font-size:.9rem;cursor:pointer;transition:transform .15s ease;-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none}.feedback-pill:hover{transform:translateY(-1px);border-color:var(--purple)}.feedback-pill-active{border:2px solid var(--purple);background:linear-gradient(180deg,#fff,#f6f1ff);color:var(--purple);box-shadow:0 4px 12px #7a42ff26}.feedback-history-card{border:1px solid #e4e8ff;border-radius:18px;padding:15px;background:#fff;display:flex;flex-direction:column;gap:10px}.feedback-history-ratings{display:flex;gap:8px;flex-wrap:wrap}.feedback-rating-chip{font-size:.78rem;font-weight:700;padding:4px 10px;border-radius:999px;border:1px solid transparent}.chip-good{background:var(--success-bg);border-color:var(--success-border);color:var(--success-text)}.chip-warn{background:var(--favorite-bg);border-color:var(--favorite-border);color:var(--favorite-text)}.chip-bad{background:var(--danger-bg);border-color:var(--danger-border);color:var(--danger-text)}.feedback-history-note{color:var(--muted);font-style:italic;line-height:1.5;margin:0;font-size:.92rem}.footer{margin-top:28px;background:linear-gradient(135deg,#121d40,#1f2d68);color:#ffffffeb;border-radius:24px;padding:24px}.footer-title{font-family:Playfair Display,Georgia,serif;font-size:1.4rem;margin:0 0 8px}.footer-copy{margin:0;color:#ffffffd1;line-height:1.7}@media (max-width: 860px){.grid,.mode-grid,.four-up,.two-up,.activity-grid,.template-grid{grid-template-columns:1fr}.quick-stats{grid-template-columns:repeat(2,1fr)}.step-header,.recent-top,.section-row,.audio-controls,.add-step-row{flex-direction:column;align-items:flex-start}.volume-control{width:100%;flex-direction:column;align-items:flex-start}.volume-control input[type=range]{width:100%}}@media (max-width: 480px){.container{padding:16px 12px 48px}.hero{padding:28px 18px;border-radius:20px}.hero h1{font-size:1.8rem}.subtitle{font-size:.95rem}.card{padding:16px;border-radius:18px}.quick-stats,.four-up{grid-template-columns:repeat(2,1fr)}.timer{font-size:3rem}.current-step-title{font-size:1.4rem}.step-header{flex-direction:column;align-items:flex-start;gap:6px}.badge{align-self:flex-start}.feedback-options{gap:8px}.feedback-pill{padding:9px 14px;font-size:.85rem}.add-step-row{justify-content:flex-start}.button-row{flex-direction:column;align-items:stretch}.button-row button{width:100%;text-align:center}.recent-grid{grid-template-columns:1fr}.activity-grid{gap:6px}.activity-day{padding:8px 4px}.activity-label{font-size:.7rem}.topbar-inner{padding:12px}.logo{font-size:1.1rem}.volume-control input[type=range]{width:100%;height:8px}.volume-control input[type=range]::-webkit-slider-thumb{width:28px;height:28px}}@supports (-webkit-touch-callout: none){.volume-control{display:none}}
