*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}html,body,#root{margin:0;padding:0;height:100%;background:#0e1116;color:#e8ecf2;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,system-ui,sans-serif;overscroll-behavior:none}button{font-family:inherit;cursor:pointer;-webkit-user-select:none;user-select:none}.app{min-height:100vh;width:100%;background:radial-gradient(ellipse at top,#161b22,#0e1116 60%);position:relative;overflow-x:hidden}.bg-grain{position:fixed;top:0;right:0;bottom:0;left:0;background-image:radial-gradient(rgba(255,255,255,.025) 1px,transparent 1px);background-size:4px 4px;pointer-events:none;z-index:1}.container{max-width:520px;margin:0 auto;padding:20px 16px 96px;position:relative;z-index:2}.home-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:24px;padding:12px 0 4px;gap:12px}.brand{font-size:10px;letter-spacing:3px;color:#7c8593;font-weight:700;margin-bottom:4px}.hello{font-size:38px;font-weight:900;color:#f0f4fa;letter-spacing:-.5px;margin:0;line-height:1}.stats-strip{display:flex;flex-wrap:wrap;gap:6px;font-size:12px;color:#9aa3b1;margin-top:10px;letter-spacing:.5px}.header-actions{display:flex;gap:8px}.icon-btn{width:44px;height:44px;border:1px solid #2a2f37;background:#181c22;color:#e8ecf2;font-size:18px;border-radius:12px;display:flex;align-items:center;justify-content:center;transition:background .15s}.icon-btn:active{background:#232830}.icon-btn.small{width:36px;height:36px;font-size:16px}.planet-wrap{position:relative;flex-shrink:0;display:flex;flex-direction:column;align-items:center}.planet-stage-label{font-size:9px;letter-spacing:1px;color:#7c8593;text-align:center;margin-top:4px;font-weight:700}.protocol-planet-row{display:flex;align-items:center;gap:14px}.protocol-side{flex:1}.protocol-banner{background:linear-gradient(135deg,#11171c,#161b22);border:1px solid #2a2f37;border-radius:12px;padding:10px 14px;margin-bottom:12px}.protocol-progress-bar{height:6px;background:#1a1e25;border-radius:999px;overflow:hidden;margin-bottom:8px}.protocol-progress-fill{height:100%;background:linear-gradient(90deg,#7fd4c8,#f5b82e);transition:width .4s ease}.protocol-text{font-size:12px;color:#c8cfd9;letter-spacing:.5px;text-align:center;font-weight:600}.daily-card.done{opacity:.7;cursor:default}.daily-card.done .daily-bar{background:linear-gradient(180deg,#7fd4c8,#7fd4c8)}.daily-card{display:flex;align-items:stretch;gap:14px;width:100%;background:linear-gradient(135deg,#1d232b,#161b22);border:1px solid #2a2f37;border-radius:16px;padding:0;color:#e8ecf2;margin-bottom:20px;overflow:hidden}.daily-bar{width:4px;background:linear-gradient(180deg,#7fd4c8,#f5b82e)}.daily-body{flex:1;text-align:left;padding:16px 0}.daily-label{font-size:10px;letter-spacing:3px;color:#f5b82e;font-weight:700;margin-bottom:4px}.daily-title{font-size:17px;font-weight:900;margin-bottom:10px;letter-spacing:.5px}.daily-list{display:flex;flex-wrap:wrap;gap:6px}.daily-chip{display:inline-block;padding:4px 10px;border:1px solid;border-radius:999px;font-size:10px;letter-spacing:1px;font-weight:700}.daily-arrow{display:flex;align-items:center;padding:0 18px;font-size:22px;color:#7fd4c8}.section-title{font-size:11px;letter-spacing:3px;color:#7c8593;font-weight:700;margin:14px 0 10px;padding-left:2px}.games-grid{display:grid;gap:10px}.game-card{display:flex;align-items:center;gap:14px;padding:16px 14px;background:#181c22;border:1px solid;border-radius:14px;text-align:left;color:#e8ecf2;width:100%;transition:transform .1s}.game-card:active{transform:scale(.985)}.game-icon{font-size:22px;font-weight:900;min-width:44px;text-align:center;letter-spacing:-1px}.game-info{flex:1;min-width:0}.game-name{font-size:15px;font-weight:900;letter-spacing:.5px;margin-bottom:2px}.game-sub{font-size:12px;color:#9aa3b1;margin-bottom:6px}.game-level{font-size:10px;color:#7c8593;letter-spacing:1.5px;font-weight:700}.game-arrow{font-size:22px;font-weight:700}.tip{background:#181c22;border:1px solid #2a2f37;border-radius:12px;padding:14px 16px;margin-top:20px}.tip-title{font-size:10px;font-weight:700;letter-spacing:3px;color:#7fd4c8;margin-bottom:6px}.tip-text{font-size:13px;color:#c8cfd9;margin:0;line-height:1.5}.game-shell{max-width:520px;margin:0 auto;padding:16px 16px 40px;position:relative;z-index:2;min-height:100vh}.game-header{display:flex;justify-content:space-between;align-items:center;padding:8px 0;gap:8px}.back-btn{width:44px;height:44px;border:1px solid #2a2f37;background:#181c22;color:#e8ecf2;font-size:22px;border-radius:12px;font-weight:700}.game-header-center{text-align:center;flex:1}.game-title{font-size:16px;font-weight:900;letter-spacing:2px}.game-meta{font-size:10px;color:#7c8593;letter-spacing:2px;margin-top:4px}.progress-bar{width:100%;height:4px;background:#1a1e25;border-radius:999px;overflow:hidden;margin:8px 0 20px}.progress-fill{height:100%;transition:width .3s ease}.game-main{display:flex;flex-direction:column;align-items:center;gap:16px}.instructions{text-align:center;padding:12px;font-size:14px;color:#c8cfd9;min-height:50px;font-weight:500}.instructions p{margin:0}.grid{display:grid;gap:8px;margin:0 auto;width:100%}.cell{aspect-ratio:1;background:#181c22;border:2px solid #2a2f37;border-radius:10px;transition:all .15s ease;display:flex;align-items:center;justify-content:center}.cell.hi{transform:scale(1.05);box-shadow:0 0 24px #ffffff26}.cell.used{background:#232b2a}.cell.picked{background:#1f2a25}.cell.wrong{background:#3a1c1c;border-color:#e94f37}.cell.static{cursor:default}.display-area{width:100%;min-height:220px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px}.big-digit{font-size:120px;font-weight:900;line-height:1;color:#7fd4c8;text-shadow:0 4px 24px rgba(127,212,200,.25)}.input-display{font-size:32px;font-weight:900;text-align:center;padding:14px 20px;background:#181c22;border:1px solid #2a2f37;border-radius:12px;min-height:56px;min-width:260px;letter-spacing:8px;color:#e8ecf2}.numpad{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;width:100%;max-width:280px}.key{padding:18px 0;font-size:22px;font-weight:700;background:#181c22;border:1px solid #2a2f37;color:#e8ecf2;border-radius:12px;transition:transform .1s,background .15s}.key:active{transform:scale(.95);background:#232830}.key-soft{background:#1f242b;color:#9aa3b1}.key-go{color:#0e1116;font-weight:900}.key-go:disabled{opacity:.4}.letterpad{display:grid;grid-template-columns:repeat(6,1fr);gap:6px;width:100%;max-width:360px}.letter-key{padding:12px 4px;font-size:14px}.span-3{grid-column:span 3}.hint{font-size:14px;color:#c8cfd9;text-align:center}.hint strong{color:#7fd4c8;letter-spacing:3px}.feedback{text-align:center;padding:8px}.feedback-label{font-size:26px;font-weight:900;letter-spacing:3px;display:inline-flex;align-items:center;gap:10px}.feedback.ok .feedback-label{color:#7fd4c8}.feedback.err .feedback-label{color:#e94f37}.feedback-hint{font-size:12px;color:#9aa3b1;margin-top:4px}.feedback-star{color:#f5b82e;font-size:32px;text-shadow:0 0 16px rgba(245,184,46,.7);display:inline-block;animation:feedbackStarPop .55s cubic-bezier(.34,1.56,.64,1) both}@keyframes feedbackStarPop{0%{transform:scale(0) rotate(-180deg);opacity:0}60%{transform:scale(1.5) rotate(15deg);opacity:1}to{transform:scale(1) rotate(0);opacity:1}}.nback-controls{width:100%;max-width:280px;display:flex;justify-content:center;margin-top:8px}.big-btn{width:100%;padding:22px;font-size:18px;font-weight:900;letter-spacing:4px;color:#0e1116;border:none;border-radius:14px}.big-btn:disabled{opacity:.35}.gonogo-stage,.cpt-stage{width:100%;max-width:360px;aspect-ratio:1;background:#181c22;border:2px solid #2a2f37;border-radius:16px;display:flex;align-items:center;justify-content:center;font-size:140px;font-weight:900;transition:background .15s;-webkit-user-select:none;user-select:none}.stim{font-size:140px;line-height:1}.trial-summary{font-size:14px;color:#c8cfd9;display:flex;flex-direction:column;gap:6px}.trial-summary-row{display:flex;justify-content:space-between;gap:16px;min-width:200px}.result-box{background:#181c22;border:1px solid #2a2f37;border-radius:16px;padding:28px 22px;margin:32px 0;text-align:center}.result-eyebrow{font-size:11px;letter-spacing:4px;font-weight:900;margin-bottom:4px}.result-title{font-size:22px;font-weight:900;letter-spacing:1.5px;margin-bottom:20px}.result-big{padding:18px 0;border-top:1px solid #2a2f37;border-bottom:1px solid #2a2f37;margin-bottom:18px}.result-big-num{font-size:72px;font-weight:900;line-height:1;color:#f0f4fa}.result-big-label{font-size:10px;letter-spacing:3px;color:#7c8593;margin-top:6px;font-weight:700}.result-rows{text-align:left;margin-bottom:18px}.result-row{display:flex;justify-content:space-between;padding:10px 0;border-bottom:1px solid #23282f;font-size:14px;color:#c8cfd9}.result-row strong{color:#f0f4fa}.daily-progress{margin:18px 0;text-align:left}.daily-progress-label{font-size:10px;letter-spacing:2px;color:#7c8593;margin-bottom:6px;font-weight:700}.daily-progress-bar{height:6px;background:#1a1e25;border-radius:999px;overflow:hidden}.daily-progress-fill{height:100%;transition:width .3s ease}.primary-btn{width:100%;padding:18px;font-size:14px;font-weight:900;letter-spacing:3px;background:#7fd4c8;color:#0e1116;border:none;border-radius:12px;margin-top:8px}.ghost-btn{width:100%;padding:14px;font-size:12px;font-weight:700;letter-spacing:2px;background:transparent;color:#7c8593;border:none;margin-top:8px}.kpi-row{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin:8px 0 16px}.kpi{background:#181c22;border:1px solid #2a2f37;border-radius:12px;padding:10px 6px;text-align:center}.kpi-num{font-size:22px;font-weight:900;color:#f0f4fa;line-height:1.1}.kpi-label{font-size:9px;letter-spacing:1.5px;color:#7c8593;margin-top:4px;font-weight:700}.filter-row{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:10px}.filter-row.scroll{flex-wrap:nowrap;overflow-x:auto;padding-bottom:4px}.filter-row.scroll::-webkit-scrollbar{display:none}.chip{padding:6px 12px;font-size:11px;letter-spacing:1.5px;font-weight:700;background:transparent;border:1px solid #2a2f37;color:#9aa3b1;border-radius:999px;white-space:nowrap}.chip.active{background:#232830;color:#e8ecf2;border-color:#3a4150}.chart-card{background:#181c22;border:1px solid #2a2f37;border-radius:12px;padding:14px 8px 14px 4px;margin-bottom:14px}.chart-title{font-size:10px;letter-spacing:2px;color:#9aa3b1;font-weight:700;padding:0 12px 10px}.chart-empty{text-align:center;padding:40px 16px;color:#7c8593;font-size:13px}.exercise-summary{display:grid;gap:8px;margin-bottom:16px}.ex-card{background:#181c22;border:1px solid #2a2f37;border-radius:12px;padding:12px 14px}.ex-card-head{display:flex;align-items:center;gap:8px;font-size:13px;margin-bottom:10px}.ex-dot{width:10px;height:10px;border-radius:50%;display:inline-block}.ex-card-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:4px;text-align:center}.ex-stat{font-size:18px;font-weight:900;color:#f0f4fa}.ex-lbl{font-size:9px;letter-spacing:1.5px;color:#7c8593;margin-top:2px;font-weight:700}.ex-domain{font-size:11px;color:#7c8593;margin-top:10px;font-style:italic}.settings-section{margin-bottom:22px}.settings-label{display:block;font-size:10px;letter-spacing:3px;color:#7c8593;font-weight:700;margin-bottom:8px}.settings-input{width:100%;padding:14px 16px;background:#181c22;border:1px solid #2a2f37;color:#e8ecf2;border-radius:12px;font-size:15px;font-family:inherit}.settings-row{display:flex;justify-content:space-between;align-items:center;width:100%;padding:16px;background:#181c22;border:1px solid #2a2f37;color:#e8ecf2;border-radius:12px;font-size:14px;text-align:left;margin-bottom:6px}.settings-row.danger{color:#e94f37}.toggle{font-size:11px;letter-spacing:2px;color:#7fd4c8;font-weight:700}.chev{color:#7c8593;font-size:16px}.about-text{font-size:13px;color:#c8cfd9;line-height:1.5}.about-text.small{font-size:12px;color:#9aa3b1}@media (max-width: 360px){.hello{font-size:32px}.big-digit{font-size:96px}.kpi-num{font-size:18px}}.report-screen .filter-row{flex-wrap:wrap}.date-row{display:flex;gap:10px;margin-bottom:12px}.date-row label{flex:1;display:flex;flex-direction:column;font-size:10px;letter-spacing:2px;color:#7c8593;font-weight:700;gap:6px}.date-row input[type=date]{padding:10px 12px;background:#181c22;border:1px solid #2a2f37;color:#e8ecf2;border-radius:10px;font-size:14px;font-family:inherit;color-scheme:dark}.action-row{display:flex;gap:8px;flex-wrap:wrap;margin-top:12px}.action-row .primary-btn,.action-row .secondary-btn{flex:1 1 200px;margin-top:0}.secondary-btn{padding:16px;font-size:13px;font-weight:700;letter-spacing:2px;background:#181c22;color:#e8ecf2;border:1px solid #2a2f37;border-radius:12px}.secondary-btn:disabled{opacity:.4}.tip.danger{border-color:#5b2a25;background:#1f1715}.report-body{background:#fff;color:#1a1a1a;padding:32px 28px;margin-top:20px;border-radius:12px;font-family:Georgia,Times New Roman,serif;line-height:1.65;font-size:14px}.report-body h1{font-size:22px;margin:0 0 8px;border-bottom:2px solid #1a1a1a;padding-bottom:8px;letter-spacing:.3px}.report-body h2{font-size:16px;margin:22px 0 10px;color:#1a1a1a;border-bottom:1px solid #d0d0d0;padding-bottom:4px;letter-spacing:.5px}.report-body h3{font-size:14px;margin:16px 0 8px}.report-body p{margin:8px 0}.report-body ul{margin:8px 0 8px 24px;padding:0}.report-body li{margin:4px 0}.report-body hr{border:none;border-top:1px solid #d0d0d0;margin:18px 0}.report-body blockquote{margin:10px 0;padding:8px 14px;border-left:3px solid #888;color:#555;font-style:italic;font-size:13px;background:#f8f8f8}.report-body strong{color:#1a1a1a}.report-body em{color:#555}.report-body code{background:#f0f0f0;padding:1px 5px;border-radius:3px;font-family:Courier New,monospace;font-size:13px}.speed-row{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;margin-bottom:4px}.speed-btn{display:flex;flex-direction:column;align-items:center;gap:4px;padding:12px 6px;background:#181c22;border:1px solid #2a2f37;color:#c8cfd9;border-radius:10px;text-align:center}.speed-btn.active{background:#1f2a35;border-color:#7fd4c8;color:#7fd4c8}.speed-label{font-size:13px;font-weight:700;letter-spacing:.5px}.speed-sub{font-size:10px;color:#7c8593;letter-spacing:.5px}.theme-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;margin-bottom:8px}.theme-btn{display:flex;flex-direction:column;align-items:center;gap:6px;padding:14px 8px;background:#181c22;border:1px solid #2a2f37;color:#c8cfd9;border-radius:12px;font-size:12px;font-weight:600;letter-spacing:1px}.theme-btn.active{background:#1f2a35;border-width:2px;padding:13px 7px}.theme-icon{font-size:26px;line-height:1}.theme-name{font-size:11px;letter-spacing:1px}.cpt-stim{font-size:110px;line-height:1}.tap-pulse{background:#1f2a35!important}.tutorial-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000c7;display:flex;align-items:center;justify-content:center;z-index:999;padding:20px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.tutorial-box{background:#11171c;border:1px solid #2a2f37;border-radius:16px;padding:22px 20px;max-width:440px;width:100%;max-height:90vh;overflow-y:auto}.tutorial-title{font-size:18px;font-weight:900;color:#7fd4c8;margin-bottom:12px;letter-spacing:1px}.tutorial-text{font-size:14px;color:#e8ecf2;line-height:1.55;margin:0 0 16px}.tutorial-examples{background:#181c22;border:1px solid #2a2f37;border-radius:10px;padding:12px 14px;margin-bottom:18px;display:flex;flex-direction:column;gap:8px}.tut-row{display:flex;align-items:center;gap:10px;font-size:13px}.tut-stim{font-size:26px;width:42px;text-align:center;flex-shrink:0}.tut-arrow{color:#7c8593}.tut-action{color:#9aa3b1}.tut-action.yes{color:#7fd4c8;font-weight:700}.tut-action.no{color:#7c8593}.kbd-hint{text-align:center;font-size:11px;color:#7c8593;margin-top:14px;letter-spacing:.5px}.kbd-hint kbd{display:inline-block;padding:2px 6px;background:#181c22;border:1px solid #2a2f37;border-radius:4px;font-family:inherit;font-size:10px;font-weight:700;color:#c8cfd9;margin:0 2px}.room-perspective-wrap{perspective:800px;margin:20px auto;max-width:360px}.room-grid{display:grid;gap:6px;transform:rotateX(35deg);transform-origin:center bottom;transform-style:preserve-3d;background:linear-gradient(180deg,transparent 0%,rgba(127,212,200,.04) 100%);padding:10px;border-radius:14px}.room-cell{aspect-ratio:1;background:#181c22;border:2px solid #2a2f37;border-radius:8px;transition:all .15s ease;display:flex;align-items:center;justify-content:center}.room-cell.picked{background:#1f2a25}.room-cell.wrong{background:#3a1c1c;border-color:#e94f37}.room-item{font-size:24px}.rotate-stage{margin:0 auto;display:inline-block}.montaje-grid{display:grid;gap:8px;margin:0 auto;max-width:380px;width:92vw}.montaje-cell{aspect-ratio:1;border:2px solid;border-radius:10px;font-size:32px;font-weight:900;transition:all .18s ease;padding:0;display:flex;align-items:center;justify-content:center}.montaje-cell:not(:disabled):active{transform:scale(.95)!important}.cube-stage{position:relative;background:radial-gradient(ellipse at center,#161b22,#0e1116 80%);border:1px solid #2a2f37;border-radius:14px;margin:0 auto}.cube-vertex{position:absolute;border:2px solid;border-radius:50%;padding:0;transition:all .18s ease;display:flex;align-items:center;justify-content:center;z-index:2}.cube-num{font-size:13px;font-weight:900;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.6)}.breath-shape-toggle{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:20px}.shape-btn{display:flex;flex-direction:column;align-items:center;gap:4px;padding:14px 8px;background:#181c22;border:1px solid #2a2f37;color:#c8cfd9;border-radius:12px;font-size:13px;font-weight:700}.shape-btn.active{background:#1f2a35;border-color:#7fd4c8;color:#7fd4c8}.shape-sub{font-size:10px;color:#7c8593;letter-spacing:.5px;font-weight:500}.breath-stage{display:flex;justify-content:center;margin:12px auto}.routine-card{background:#181c22;border:2px solid #2a2f37;border-left-width:4px;border-radius:12px;margin-bottom:10px;overflow:hidden}.routine-head{display:flex;align-items:center;gap:12px;padding:14px;background:transparent;border:none;color:#e8ecf2;width:100%;text-align:left}.routine-icon{font-size:28px;width:52px;height:52px;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.routine-info{flex:1;min-width:0}.routine-name{font-size:16px;font-weight:900;letter-spacing:.5px}.routine-sub{font-size:11px;color:#9aa3b1;margin:4px 0 6px;letter-spacing:.5px}.routine-progress-bar{height:4px;background:#1a1e25;border-radius:999px;overflow:hidden}.routine-progress-fill{height:100%;transition:width .4s ease}.routine-arrow{color:#7c8593;font-size:16px;padding:0 6px}.routine-steps{padding:8px 14px 14px;border-top:1px solid #2a2f37}.step-row{display:flex;align-items:center;gap:12px;padding:12px 8px;background:transparent;border:none;width:100%;text-align:left;border-bottom:1px solid #1a1e25}.step-row:last-of-type{border-bottom:none}.step-row.done .step-name{text-decoration:line-through;color:#7c8593}.step-check{width:28px;height:28px;border:2px solid;border-radius:8px;display:flex;align-items:center;justify-content:center;color:#0e1116;font-weight:900;flex-shrink:0}.step-icon{font-size:24px;flex-shrink:0}.step-name{flex:1;color:#e8ecf2;font-size:14px;font-weight:600}.step-time{font-size:11px;color:#7c8593;letter-spacing:1px}.step-editor{display:flex;align-items:center;gap:6px;margin-bottom:8px;padding:8px;background:#11171c;border-radius:8px;flex-wrap:wrap}.step-editor .settings-input{margin:0}.step-name-input{flex:1;min-width:120px}.step-time-input{width:70px}.step-controls{display:flex;gap:4px}.step-controls button{background:#2a2f37;border:none;color:#e8ecf2;width:32px;height:32px;border-radius:6px;font-size:14px}.step-controls button.danger{background:#5b2a25;color:#e94f37}.step-controls button:disabled{opacity:.3}.emoji-trigger{background:#181c22;border:1px solid #2a2f37;color:#fff;font-size:28px;padding:6px 12px;border-radius:10px;cursor:pointer;display:inline-block}.emoji-trigger.small{font-size:20px;padding:4px 8px}.emoji-picker{display:grid;grid-template-columns:repeat(8,1fr);gap:4px;background:#11171c;border:1px solid #2a2f37;border-radius:10px;padding:8px;margin-top:8px;max-height:200px;overflow-y:auto;width:100%}.emoji-pick{background:transparent;border:none;font-size:22px;padding:4px;border-radius:6px}.emoji-pick:active{background:#1f2530}.diary-kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin:8px 0 16px}.diary-actions{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:18px}.diary-action{display:flex;flex-direction:column;align-items:center;gap:6px;padding:18px 10px;background:#181c22;border:1px solid #2a2f37;border-radius:14px;color:#e8ecf2;text-align:center}.diary-action.quick{border-color:#7fd4c8}.diary-action.abc{border-color:#e94f37}.diary-action-icon{font-size:32px;line-height:1}.diary-action-title{font-size:14px;font-weight:900;letter-spacing:1px}.diary-action-sub{font-size:11px;color:#9aa3b1}.diary-form{background:#181c22;border:1px solid #2a2f37;border-radius:14px;padding:18px 16px;margin-bottom:20px}.diary-range{width:100%;margin:6px 0 4px;-webkit-appearance:none;height:6px;background:#2a2f37;border-radius:999px}.diary-range::-webkit-slider-thumb{-webkit-appearance:none;width:22px;height:22px;border-radius:50%;background:#7fd4c8;cursor:pointer}.diary-range::-moz-range-thumb{width:22px;height:22px;border-radius:50%;background:#7fd4c8;cursor:pointer;border:none}.diary-range-labels{display:flex;justify-content:space-between;font-size:10px;color:#7c8593;letter-spacing:1px}.abc-section{display:flex;align-items:center;gap:10px;margin:18px 0 8px}.abc-letter{width:36px;height:36px;background:#e94f37;color:#0e1116;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:20px;font-weight:900}.abc-title{font-size:13px;font-weight:700;letter-spacing:1px;color:#e8ecf2;text-transform:uppercase}.tag-cloud{display:flex;flex-wrap:wrap;gap:5px;margin-bottom:8px}.tag-btn{padding:7px 11px;background:#181c22;border:1px solid #2a2f37;color:#c8cfd9;border-radius:999px;font-size:11px;font-weight:600}.tag-btn.active{background:#1f2a35;border-color:#7fd4c8;color:#7fd4c8}.outcome-row{display:grid;grid-template-columns:1fr 1fr;gap:6px}.outcome-btn{padding:10px;background:#181c22;border:1px solid #2a2f37;color:#c8cfd9;border-radius:10px;font-size:11px;font-weight:600;text-align:left}.outcome-btn.active{background:#1f2a35;border-color:#7fd4c8;color:#e8ecf2}.diary-entry{background:#181c22;border:1px solid #2a2f37;border-radius:10px;padding:12px;margin-bottom:8px;border-left-width:3px}.diary-entry.quick{border-left-color:#7fd4c8}.diary-entry.abc{border-left-color:#e94f37}.diary-entry-head{display:flex;justify-content:space-between;margin-bottom:8px}.diary-entry-date{font-size:11px;color:#7c8593;letter-spacing:1px}.diary-del-btn{background:transparent;border:none;color:#7c8593;font-size:18px;padding:0 4px}.diary-entry-mood{font-size:14px;color:#e8ecf2;margin-bottom:4px}.diary-entry-pos{font-size:13px;color:#7fd4c8;margin-bottom:4px}.diary-entry-note{font-size:12px;color:#c8cfd9;font-style:italic}.diary-entry-line{font-size:12px;color:#c8cfd9;margin:4px 0;line-height:1.4}.diary-entry-line strong{color:#e8ecf2}.emotion-stage{display:flex;flex-direction:column;align-items:center;margin:12px auto}.emotion-face-wrap{background:transparent;border:4px solid #2A2A2A;border-radius:50%;padding:6px;display:inline-block;transition:border-color .3s}.emoji-face-circle{background:#ffe7a8;border-radius:50%;display:flex;align-items:center;justify-content:center;line-height:1}.emoji-face-glyph{line-height:1;display:block;-webkit-user-select:none;user-select:none}.emotion-answer{margin-top:10px;font-size:18px;font-weight:900;letter-spacing:1px}.emotion-options{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-top:20px;max-width:380px;width:92vw;margin-left:auto;margin-right:auto}.emotion-option{padding:16px 8px;background:#181c22;border:2px solid;border-radius:12px;color:#e8ecf2;font-size:15px;font-weight:700;letter-spacing:.5px;transition:transform .1s,background .15s}.emotion-option:not(:disabled):active{transform:scale(.95)}.emotion-option.picked{background:#2a1a1a}.emotion-option.correct{background:#1a2a25}.chaos-stage{position:relative;background:radial-gradient(ellipse at center,#1a1f27,#0e1116 80%);border:1px solid #2a2f37;border-radius:14px;margin:0 auto;overflow:hidden}.chaos-hit{position:absolute;background:transparent;border:none;padding:0;display:flex;align-items:center;justify-content:center;z-index:2}.chaos-num{font-size:14px;font-weight:900;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.6);pointer-events:none}.circle-stage{position:relative;background:radial-gradient(ellipse at center,#161b22,#0e1116 80%);border:1px solid #2a2f37;border-radius:14px;margin:0 auto;overflow:hidden}.circle-ring{position:absolute;border:1px dashed #2a2f37;border-radius:50%;pointer-events:none}.circle-point{position:absolute;border:2px solid;border-radius:50%;padding:0;transition:all .18s ease;display:flex;align-items:center;justify-content:center}.circle-point:not(:disabled):active{transform:scale(.92)!important}.circle-num{font-size:14px;font-weight:900;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.6)}.hidden-digits-row{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;margin:24px auto;max-width:380px}.hd-circle{width:68px;height:68px;border-radius:50%;border:2px solid;padding:0;transition:all .2s ease;position:relative;display:flex;align-items:center;justify-content:center}.hd-value{font-size:30px;font-weight:900;line-height:1}.hd-order{position:absolute;bottom:-3px;right:-3px;background:#7fd4c8;color:#0e1116;width:22px;height:22px;border-radius:50%;font-size:12px;font-weight:900;display:flex;align-items:center;justify-content:center}.asteroids-stage{position:relative;background:radial-gradient(ellipse at center,#161b22,#0e1116 80%);border:1px solid #2a2f37;border-radius:14px;margin:0 auto;overflow:hidden}.asteroid{position:absolute;border:2px solid;border-radius:50%;padding:0;transition:all .18s ease;display:flex;align-items:center;justify-content:center}.asteroid:not(:disabled):active{transform:scale(.92)!important}.asteroid-num{font-size:16px;font-weight:900;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.5)}.memo-grid{display:grid;gap:10px;margin:0 auto;width:100%}.memo-card{aspect-ratio:1;background:#181c22;border:2px solid #2a2f37;border-radius:12px;display:flex;align-items:center;justify-content:center;transition:all .18s ease;padding:0}.memo-card:not(:disabled):active{transform:scale(.96)}.memo-card.flipped{transform:rotateY(0)}.memo-card.matched{opacity:.7}.memo-icon{font-size:32px;font-weight:700;line-height:1}.onboarding-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0e1116f5;z-index:9990;display:flex;align-items:center;justify-content:center;padding:20px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.onboarding-box{background:linear-gradient(135deg,#1d232b,#11171c);border:1px solid #2a2f37;border-radius:20px;padding:36px 28px 26px;max-width:420px;width:100%;text-align:center}.onboarding-icon{font-size:88px;line-height:1;margin-bottom:16px;animation:bounceIn .7s cubic-bezier(.34,1.56,.64,1) both}@keyframes bounceIn{0%{transform:scale(0) rotate(-15deg);opacity:0}60%{transform:scale(1.2) rotate(8deg);opacity:1}to{transform:scale(1) rotate(0);opacity:1}}.onboarding-title{font-size:26px;font-weight:900;letter-spacing:1px;margin-bottom:14px;line-height:1.15}.onboarding-body{font-size:15px;color:#c8cfd9;line-height:1.6;margin:0 0 24px}.onboarding-dots{display:flex;justify-content:center;gap:8px;margin:0 0 22px}.onboarding-dots .dot{width:8px;height:8px;border-radius:50%;background:#2a2f37;transition:all .3s ease}.onboarding-dots .dot.active{background:#7fd4c8;width:24px;border-radius:4px}.stars-row{display:flex;justify-content:center;gap:4px;margin:8px 0 14px}.star{color:#2a2f37;filter:grayscale(.4);transition:color .2s}.star.filled{color:#f5b82e;filter:none;text-shadow:0 0 12px rgba(245,184,46,.5)}.star.pop{animation:starPop .5s cubic-bezier(.34,1.56,.64,1) both}@keyframes starPop{0%{transform:scale(0) rotate(-30deg);opacity:0}60%{transform:scale(1.4) rotate(8deg);opacity:1}to{transform:scale(1) rotate(0);opacity:1}}.result-medal{font-size:56px;text-align:center;line-height:1;margin:8px 0 4px;animation:medalDrop .7s cubic-bezier(.34,1.56,.64,1) both}@keyframes medalDrop{0%{transform:translateY(-30px) scale(.5);opacity:0}to{transform:translateY(0) scale(1);opacity:1}}.celebration-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000d9;z-index:9999;display:flex;align-items:center;justify-content:center;padding:20px;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);overflow:hidden}.confetti-layer{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;overflow:hidden}.confetti-piece{position:absolute;top:-20px;width:10px;height:14px;border-radius:2px;animation:confettiFall linear infinite}@keyframes confettiFall{0%{transform:translateY(0) rotate(0);opacity:1}90%{opacity:1}to{transform:translateY(110vh) rotate(720deg);opacity:0}}.celebration-box{background:linear-gradient(135deg,#1d232b,#11171c);border:2px solid #F5B82E;border-radius:20px;padding:32px 26px;max-width:420px;width:100%;text-align:center;position:relative;z-index:1;box-shadow:0 20px 60px #00000080}.celebration-trophy{font-size:96px;line-height:1;margin-bottom:12px;animation:trophyBounce 1.5s ease-in-out infinite}@keyframes trophyBounce{0%,to{transform:translateY(0) scale(1)}50%{transform:translateY(-12px) scale(1.06)}}.celebration-title{font-size:22px;font-weight:900;color:#f5b82e;letter-spacing:2px;margin-bottom:8px}.celebration-name{font-size:16px;font-weight:700;color:#e8ecf2;margin-bottom:18px}.celebration-text{font-size:14px;color:#c8cfd9;line-height:1.55;margin:0 0 14px}.celebration-text.small{font-size:12px;color:#9aa3b1}.coach-card{margin:16px 0;padding:14px 16px;background:#11171c;border:1px solid #2a2f37;border-left-width:3px;border-radius:10px;text-align:left}.coach-head{font-size:10px;letter-spacing:3px;color:#7fd4c8;font-weight:700;margin-bottom:6px}.coach-body{font-size:14px;color:#e8ecf2;line-height:1.5}.coach-body.err{color:#9aa3b1;font-size:12px}.insights-card{background:#11171c;border:1px solid #2a2f37;border-radius:14px;padding:14px;margin-bottom:16px}.insights-head{font-size:10px;letter-spacing:3px;color:#9b5de5;font-weight:700;margin-bottom:10px}.insights-skel{color:#7c8593;font-size:12px;padding:8px 4px}.insight-row{background:#181c22;border-left:3px solid #7c8593;padding:10px 12px;margin-bottom:8px;border-radius:6px}.insight-row:last-child{margin-bottom:0}.insight-title{font-size:13px;font-weight:700;color:#f0f4fa;margin-bottom:3px}.insight-text{font-size:12px;color:#c8cfd9;line-height:1.45}.daily-motivo{margin-top:10px;font-size:11px;color:#9aa3b1;font-style:italic;line-height:1.4}.mode-toggle{margin:12px 0}.mode-label{font-size:10px;letter-spacing:3px;color:#7c8593;font-weight:700;margin-bottom:8px}.mode-row{display:flex;gap:8px}.mode-btn{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;padding:14px 8px;background:#181c22;border:1px solid #2a2f37;color:#c8cfd9;border-radius:12px;font-size:12px;font-weight:700;letter-spacing:1.5px;transition:all .15s}.mode-btn.active{background:#1f2a35;border-color:#7fd4c8;color:#7fd4c8}.mode-sub{font-size:9px;letter-spacing:.5px;font-weight:400;text-transform:none;opacity:.7}.chat-screen{display:flex;flex-direction:column;min-height:100vh;padding-bottom:8px}.chat-list{flex:1;display:flex;flex-direction:column;gap:10px;padding:8px 4px 16px;overflow-y:auto}.chat-empty{background:#11171c;border:1px solid #2a2f37;border-radius:14px;padding:18px 16px;text-align:center}.chat-empty-title{font-size:14px;font-weight:700;color:#7fd4c8;margin-bottom:8px;letter-spacing:1px}.chat-empty p{font-size:13px;color:#c8cfd9;line-height:1.5;margin:0 0 16px}.chat-suggestions{display:flex;flex-direction:column;gap:6px}.chat-sug{padding:10px 12px;background:#181c22;border:1px solid #2a2f37;color:#c8cfd9;border-radius:10px;font-size:12px;text-align:left;font-family:inherit}.chat-sug:active{background:#232830}.chat-msg{display:flex}.chat-msg.user{justify-content:flex-end}.chat-msg.assistant{justify-content:flex-start}.chat-bubble{max-width:80%;padding:10px 14px;border-radius:14px;font-size:14px;line-height:1.45;white-space:pre-wrap;word-wrap:break-word}.chat-msg.user .chat-bubble{background:#1f2a35;color:#e8ecf2;border:1px solid #2a3a4d;border-bottom-right-radius:4px}.chat-msg.assistant .chat-bubble{background:#181c22;color:#e8ecf2;border:1px solid #2a2f37;border-bottom-left-radius:4px}.chat-bubble.err{color:#e94f37;border-color:#5b2a25}.chat-input-row{display:flex;gap:8px;padding:8px 0;position:sticky;bottom:0;background:linear-gradient(180deg,transparent,#0E1116 30%)}.chat-input{flex:1;padding:12px 14px;background:#181c22;border:1px solid #2a2f37;color:#e8ecf2;border-radius:12px;font-size:14px;font-family:inherit;resize:none}.chat-input:focus{outline:none;border-color:#7fd4c8}.chat-send{width:48px;align-self:stretch;background:#7fd4c8;color:#0e1116;border:none;border-radius:12px;font-size:22px;font-weight:900}.chat-send:disabled{opacity:.35}.skeleton{color:#7c8593;font-style:italic;animation:pulse 1.4s ease-in-out infinite}@keyframes pulse{0%,to{opacity:.5}50%{opacity:1}}.settings-label.sub{font-size:9px;letter-spacing:2px;color:#9aa3b1;margin-top:4px;margin-bottom:6px}.row-hint{color:#7c8593;font-size:11px;font-weight:400}@media print{@page{size:A4;margin:18mm 16mm}html,body,#root,.app,.container{background:#fff!important;color:#000!important}.bg-grain,.no-print{display:none!important}.container{max-width:none;padding:0}.report-body{background:#fff!important;color:#000!important;padding:0;margin:0;border-radius:0;font-size:11pt}.report-body h1{font-size:18pt}.report-body h2{font-size:13pt;page-break-after:avoid}.report-body h3{font-size:11pt;page-break-after:avoid}.report-body blockquote,.report-body ul,.report-body p{page-break-inside:avoid}}
