@import "https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&display=swap";*{box-sizing:border-box;margin:0;padding:0}:root{--bg:#0a0a0f;--surface:#16161f;--surface-hover:#1e1e2a;--border:#ffffff0f;--text:#f0f0f5;--text-muted:#8888a0;--radius:16px;--transition:.2s cubic-bezier(.4, 0, .2, 1)}body{background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100dvh;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}.home,.game-page{max-width:480px;margin:0 auto;padding:3rem 1.25rem 2rem}.home-header{text-align:center;margin-bottom:2.5rem}.home-header h1{letter-spacing:-.03em;margin-bottom:.5rem;font-size:1.75rem;font-weight:800}.home-header p{color:var(--text-muted);font-size:.9rem;font-weight:400}.game-list{flex-direction:column;gap:.75rem;display:flex}.game-card{border-radius:var(--radius);color:#fff;letter-spacing:-.01em;transition:transform var(--transition), box-shadow var(--transition);align-items:center;gap:1rem;padding:1.25rem 1.5rem;font-size:1.1rem;font-weight:600;text-decoration:none;display:flex;position:relative;overflow:hidden}.game-card:before{content:"";pointer-events:none;background:linear-gradient(135deg,#ffffff1a 0%,#0000 60%);position:absolute;inset:0}.game-card:active{transform:scale(.97)}.game-card .game-number{opacity:.3;font-size:2rem;font-weight:800;line-height:1}.game-card .game-info{flex-direction:column;gap:.15rem;display:flex}.game-card .game-subtitle{opacity:.7;font-size:.75rem;font-weight:400}.game-card .arrow{opacity:.5;margin-left:auto;font-size:1.25rem}.game-page .back-link{color:var(--text-muted);transition:color var(--transition);align-items:center;gap:.35rem;margin-bottom:1.5rem;font-size:.85rem;font-weight:500;text-decoration:none;display:inline-flex}.game-page .back-link:active{color:var(--text)}.game-page h1{letter-spacing:-.03em;margin-bottom:.35rem;font-size:1.5rem;font-weight:800}.game-page .page-subtitle{color:var(--text-muted);margin-bottom:2rem;font-size:.85rem}.section-list{flex-direction:column;gap:.75rem;display:flex}.section-card{border-radius:var(--radius);background:var(--surface);border:1px solid var(--border);transition:background var(--transition), transform var(--transition);cursor:pointer;align-items:center;gap:1rem;padding:1.25rem 1.5rem;font-size:1rem;font-weight:500;display:flex}.section-card:active{background:var(--surface-hover);transform:scale(.97)}.section-card .section-icon{border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;font-size:1.25rem;display:flex}.section-card .section-info{flex-direction:column;gap:.15rem;display:flex}.section-card .section-desc{color:var(--text-muted);font-size:.75rem;font-weight:400}.section-card .arrow{color:var(--text-muted);margin-left:auto;font-size:1.1rem}@media (width>=600px){.home,.game-page{padding-top:4rem}.game-card:hover{transform:translateY(-2px);box-shadow:0 8px 24px #0006}.section-card:hover{background:var(--surface-hover);transform:translateY(-1px)}.game-page .back-link:hover{color:var(--text)}}.confidant-list{flex-direction:column;gap:.5rem;display:flex}.confidant-row{background:var(--surface);border:1px solid var(--border);border-radius:12px;align-items:center;gap:1rem;padding:.875rem 1.25rem;display:flex}.confidant-arcana{text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted);min-width:80px;font-size:.7rem;font-weight:600}.confidant-info{flex-direction:column;gap:.1rem;display:flex}.confidant-character{font-size:.95rem;font-weight:600}.confidant-name{color:var(--text-muted);font-size:.75rem}a.section-card{color:inherit;text-decoration:none}a.confidant-row{color:inherit;transition:background var(--transition), transform var(--transition);text-decoration:none}a.confidant-row:active{background:var(--surface-hover);transform:scale(.98)}.confidant-note{color:var(--text-muted);background:var(--surface);border:1px solid var(--border);border-radius:10px;margin-bottom:1.5rem;padding:.75rem 1rem;font-size:.8rem;line-height:1.5}.auto-badge{text-align:center;color:var(--text-muted);padding:2rem 0;font-size:.9rem}.rank-list{flex-direction:column;gap:1.25rem;display:flex}.rank-block{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:1rem 1.25rem;scroll-margin-top:1rem}.rank-header{text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted);margin-bottom:.75rem;font-size:.85rem;font-weight:700}.rank-auto-note{color:var(--text-muted);font-size:.8rem;font-style:italic}.choices{flex-direction:column;gap:1rem;display:flex}.choice-question{color:var(--text);margin-bottom:.5rem;font-size:.85rem;font-weight:500;line-height:1.4}.answer-list{flex-direction:column;gap:.35rem;list-style:none;display:flex}.answer{border-radius:8px;justify-content:space-between;align-items:center;padding:.5rem .75rem;font-size:.8rem;display:flex}.answer.best{background:#22c55e1f;border:1px solid #22c55e40}.answer.good{background:#eab30814;border:1px solid #eab30833}.answer.neutral{border:1px solid var(--border);background:#ffffff08}.answer-text{flex:1}.answer-points{text-align:right;min-width:28px;font-size:.75rem;font-weight:700}.answer.best .answer-points{color:#22c55e}.answer.good .answer-points{color:#eab308}.answer.neutral .answer-points{color:var(--text-muted)}.quiz-header{justify-content:space-between;align-items:flex-start;margin-bottom:1.5rem;display:flex}.quiz-header h1{margin-bottom:.25rem}.drawer-toggle{background:var(--surface);border:1px solid var(--border);cursor:pointer;border-radius:10px;justify-content:center;align-items:center;width:42px;height:42px;font-size:1.2rem;display:flex}.quiz-list{flex-direction:column;gap:1.25rem;display:flex}.quiz-date-group{scroll-margin-top:1rem}.quiz-date-label{color:var(--text-muted);align-items:center;gap:.5rem;margin-bottom:.5rem;font-size:.85rem;font-weight:700;display:flex}.quiz-type-badge{text-transform:uppercase;letter-spacing:.05em;border-radius:4px;padding:.15rem .5rem;font-size:.65rem;font-weight:600}.quiz-type-badge.class{color:#60a5fa;background:#3b82f626}.quiz-type-badge.exam{color:#facc15;background:#eab30826}.quiz-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;margin-bottom:.5rem;padding:.875rem 1rem}.quiz-question{color:var(--text);margin-bottom:.4rem;font-size:.85rem;line-height:1.4}.quiz-answer{color:#22c55e;font-size:.85rem;font-weight:600}.drawer-backdrop{z-index:90;background:#0009;position:fixed;inset:0}.drawer{background:var(--bg);border-left:1px solid var(--border);z-index:100;flex-direction:column;width:280px;transition:transform .25s cubic-bezier(.4,0,.2,1);display:flex;position:fixed;top:0;bottom:0;right:0;transform:translate(100%)}.drawer.open{transform:translate(0)}.drawer-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:1.25rem 1rem;font-size:.95rem;font-weight:600;display:flex}.drawer-header button{color:var(--text-muted);cursor:pointer;background:0 0;border:none;font-size:1.2rem}.drawer-content{flex:1;padding:1rem;overflow-y:auto}.drawer-month{margin-bottom:1rem}.drawer-month-label{text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);margin-bottom:.5rem;font-size:.7rem;font-weight:700}.drawer-dates{flex-wrap:wrap;gap:.35rem;display:flex}.drawer-date-btn{background:var(--surface);border:1px solid var(--border);color:var(--text);cursor:pointer;width:36px;height:36px;transition:background var(--transition);border-radius:8px;font-size:.8rem;font-weight:500}.drawer-date-btn:active{background:var(--surface-hover)}.month-nav{-webkit-overflow-scrolling:touch;gap:.35rem;margin-bottom:1.5rem;padding-bottom:.5rem;display:flex;overflow-x:auto}.month-nav::-webkit-scrollbar{display:none}.month-btn{border:1px solid var(--border);background:var(--surface);color:var(--text-muted);cursor:pointer;transition:all var(--transition);border-radius:8px;flex-shrink:0;padding:.45rem .75rem;font-size:.75rem;font-weight:600}.month-btn.active{color:#000;background:#fff;border-color:#fff}.calendar-list{flex-direction:column;gap:.5rem;display:flex}.cal-entry{background:var(--surface);border:1px solid var(--border);border-radius:12px;gap:.75rem;padding:.875rem 1rem;display:flex}.cal-date-col{flex-direction:column;align-items:center;min-width:36px;padding-top:.1rem;display:flex}.cal-day-num{font-size:1.1rem;font-weight:700;line-height:1}.cal-day-name{text-transform:uppercase;color:var(--text-muted);margin-top:.2rem;font-size:.6rem;font-weight:600}.cal-content{flex:1;min-width:0}.cal-slot{align-items:baseline;gap:.5rem;margin-bottom:.3rem;display:flex}.cal-slot-label{text-transform:uppercase;color:var(--text-muted);min-width:26px;font-size:.6rem;font-weight:700}.cal-slot-text{font-size:.8rem;line-height:1.3}.cal-notes{color:#60a5fa;margin-top:.25rem;font-size:.7rem;font-style:italic}.cal-entry{cursor:pointer;transition:background var(--transition)}.cal-entry:active{background:var(--surface-hover)}.dialog-backdrop{z-index:90;background:#000000b3;position:fixed;inset:0}.dialog{background:var(--bg);border-top:1px solid var(--border);z-index:100;border-radius:20px 20px 0 0;flex-direction:column;max-height:85dvh;animation:.25s cubic-bezier(.4,0,.2,1) slideUp;display:flex;position:fixed;bottom:0;left:0;right:0}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.dialog-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:1rem 1.25rem;display:flex}.dialog-header h2{font-size:1.1rem;font-weight:700}.dialog-header button{color:var(--text-muted);cursor:pointer;background:0 0;border:none;padding:.25rem;font-size:1.3rem}.dialog-body{scrollbar-width:thin;scrollbar-color:#ffffff26 transparent;flex-direction:column;gap:1.25rem;padding:1rem 1.25rem 2rem;display:flex;overflow-y:auto}.dialog-section h3{text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted);margin-bottom:.75rem;font-size:.8rem;font-weight:700}.dialog-slot{align-items:baseline;gap:.5rem;margin-bottom:.35rem;font-size:.85rem;display:flex}.dialog-quiz,.dialog-confidant{background:var(--surface);border:1px solid var(--border);border-radius:10px;margin-bottom:.5rem;padding:.75rem 1rem}.dialog-conf-name{margin-bottom:.5rem;font-size:.85rem;font-weight:600}@media (width>=600px){.dialog{border-radius:20px;width:90%;max-width:480px;max-height:80vh;animation:.15s fadeIn;inset:50% auto auto 50%;transform:translate(-50%,-50%)}@keyframes fadeIn{0%{opacity:0;transform:translate(-50%)}to{opacity:1;transform:translate(-50%,-50%)}}}.mode-toggle{background:var(--surface);border:1px solid var(--border);border-radius:10px;margin-bottom:1.25rem;padding:.2rem;display:flex}.toggle-btn{color:var(--text-muted);cursor:pointer;transition:all var(--transition);background:0 0;border:none;border-radius:8px;flex:1;padding:.5rem;font-size:.8rem;font-weight:600}.toggle-btn.active{color:#000;background:#fff}.setup-panel{flex-direction:column;gap:1.25rem;margin-top:.5rem;display:flex}.setup-field label{text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted);margin-bottom:.5rem;font-size:.75rem;font-weight:700;display:block}.setup-input{border:1px solid var(--border);background:var(--surface);width:100%;color:var(--text);border-radius:8px;padding:.6rem .75rem;font-size:.9rem}.setup-stats,.setup-ranks{flex-direction:column;gap:.4rem;display:flex}.stat-row,.rank-row{background:var(--surface);border:1px solid var(--border);border-radius:8px;justify-content:space-between;align-items:center;padding:.4rem .75rem;display:flex}.stat-name,.rank-name{font-size:.8rem;font-weight:500}.stat-input{border:1px solid var(--border);background:var(--bg);width:48px;color:var(--text);text-align:center;border-radius:6px;padding:.3rem .4rem;font-size:.85rem}.generate-btn{color:#000;cursor:pointer;transition:opacity var(--transition);background:#fff;border:none;border-radius:10px;padding:.75rem;font-size:.9rem;font-weight:700}.generate-btn:disabled{opacity:.4;cursor:not-allowed}.reset-btn{border:1px solid var(--border);background:var(--surface);width:100%;color:var(--text);cursor:pointer;border-radius:10px;margin-top:1.5rem;padding:.65rem;font-size:.8rem;font-weight:600;display:block}.cal-custom{border-color:#a855f74d}.cal-highlight{color:#a855f7;font-weight:600}.feasibility-banner{border-radius:10px;margin-bottom:1rem;padding:.75rem 1rem;font-size:.8rem;line-height:1.5}.feasibility-banner.feasible{color:#4ade80;background:#22c55e1a;border:1px solid #22c55e4d}.feasibility-banner.not-feasible{color:#f87171;background:#ef44441a;border:1px solid #ef44444d}.feasibility-banner ul{margin-top:.4rem;padding:0;list-style:none}.feasibility-banner li{opacity:.9;padding:.15rem 0;font-size:.75rem}.feasibility-banner.stat-warning{color:#fbbf24;background:#eab3081a;border:1px solid #eab3084d;margin-top:.5rem}.completion-dates{border:1px solid var(--border);border-radius:10px;margin-bottom:1rem;overflow:hidden}.completion-dates summary{cursor:pointer;background:var(--surface);padding:.7rem 1rem;font-size:.8rem;font-weight:600}.completion-list{padding:.5rem 1rem}.completion-row{border-bottom:1px solid var(--border);justify-content:space-between;padding:.35rem 0;font-size:.75rem;display:flex}.completion-row:last-child{border-bottom:none}.completion-name{color:var(--text)}.completion-date{color:var(--text-muted);font-weight:600}.rank-location{color:#60a5fa;margin-bottom:.5rem;font-size:.7rem}.cal-quiz-badge{color:#facc15;margin-bottom:.3rem;font-size:.65rem;font-weight:600;display:inline-block}.weather-badge{text-transform:capitalize;font-size:.8rem;font-weight:600}.act-list{flex-direction:column;gap:.4rem;display:flex}.act-item{background:var(--surface);border:1px solid var(--border);border-radius:8px;flex-direction:column;gap:.1rem;padding:.5rem .75rem;display:flex}.act-item.act-confidant{cursor:pointer}.act-item.act-locked{opacity:.8;border-color:#eab30866}.act-name{font-size:.8rem;font-weight:600}.act-gains{color:#22c55e;font-size:.7rem;font-weight:500}.act-detail{color:var(--text-muted);font-size:.65rem}.act-note{color:var(--text-muted);font-size:.65rem;font-style:italic}.act-req{color:#fbbf24;font-size:.65rem;font-weight:600}.act-group{border:1px solid var(--border);border-radius:8px;overflow:hidden}.act-group-header{border-bottom:1px solid var(--border);border-radius:8px 8px 0 0}.act-sub{border-top:1px solid var(--border);border-radius:0;padding-left:1rem}.act-sub:first-of-type{border-top:none}.act-sub-line{justify-content:space-between;align-items:center;gap:.5rem;display:flex}.rank-header-row{justify-content:space-between;align-items:center;margin-bottom:.75rem;display:flex}.rank-header-row .rank-header{margin-bottom:0}.rank-tick{cursor:pointer;width:20px;height:20px;transition:all var(--transition);background:0 0;border-radius:50%;justify-content:center;align-items:center;font-size:.6rem;display:flex;border:1px solid var(--text-muted)!important;color:#0000!important;font-size:14px!important}.rank-tick.ticked{background:#22c55e;color:#fff!important;border-color:#22c55e!important}.dialog-nav{color:var(--text-muted);cursor:pointer;background:0 0;border:none;min-width:30px;padding:0 .2rem;font-size:1.5rem}.dialog-date-nav{align-items:center;gap:0;display:flex}.dialog-date-nav .dialog-nav:first-child{margin-left:-10px}.dialog-date-nav h2{text-align:center;min-width:140px}.dialog-close,.dialog-save{margin-left:auto}.cal-done-tick{color:#fff;background:#22c55e;border-radius:50%;justify-content:center;align-items:center;width:14px;height:14px;font-size:.5rem;display:flex;position:absolute;top:.5rem;right:.5rem}.cal-entry{position:relative}.drawer-handle{background:#fff3;border-radius:2px;width:36px;height:4px;position:absolute;top:.5rem;left:50%;transform:translate(-50%)}.dialog-header{touch-action:none;padding-top:1.5rem}.quiz-done-tick{color:#fff;background:#22c55e;border-radius:50%;justify-content:center;align-items:center;width:14px;height:14px;margin-left:auto;font-size:.5rem;display:inline-flex}
