@import"https://fonts.googleapis.com/css2?family=Playfair+Display:wght@400;700&family=Inter:wght@400;500;600&display=swap";*,*:before,*:after{box-sizing:border-box}html,body,#root{height:100%;margin:0;padding:0}body{background:var(--color-table);color:var(--color-text-primary);font-family:var(--font-ui);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overscroll-behavior:none}.app-shell{display:flex;flex-direction:column;height:100%;max-width:600px;margin:0 auto;position:relative}.app-main{flex:1;overflow:hidden;padding-bottom:56px}.screen{height:100%;overflow-y:auto;-webkit-overflow-scrolling:touch}.btn-primary{background:var(--color-accent);color:#000;border:none;border-radius:8px;padding:10px 18px;font-family:var(--font-ui);font-size:14px;font-weight:600;cursor:pointer;transition:background .15s ease;-webkit-tap-highlight-color:transparent}.btn-secondary{background:transparent;color:var(--color-text-secondary);border:1px solid var(--color-border);border-radius:8px;padding:10px 18px;font-family:var(--font-ui);font-size:14px;cursor:pointer;transition:color .15s,border-color .15s;-webkit-tap-highlight-color:transparent}.nav{position:fixed;bottom:0;left:0;right:0;height:56px;background:var(--color-surface);border-top:1px solid var(--color-border);display:flex;align-items:stretch;z-index:100;padding-bottom:env(safe-area-inset-bottom,0)}.nav-tab{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;cursor:pointer;text-decoration:none;color:var(--color-text-secondary);font-family:var(--font-ui);font-size:10px;font-weight:500;transition:color .15s ease;-webkit-tap-highlight-color:transparent;border:none;background:none;padding:0}.nav-tab:hover,.nav-tab.active{color:var(--color-accent)}.nav-tab-icon-wrap{position:relative;display:inline-flex;align-items:center;justify-content:center}.nav-tab-icon{font-size:20px;line-height:1}.nav-badge{position:absolute;top:-4px;right:-8px;min-width:16px;height:16px;padding:0 4px;border-radius:8px;background:var(--color-danger);color:#fff;font-family:var(--font-ui);font-size:9px;font-weight:700;line-height:16px;text-align:center;box-sizing:border-box;pointer-events:none}.home-screen{display:flex;flex-direction:column;align-items:center;padding:40px 20px 20px;gap:28px}.home-header{text-align:center}.home-title{font-family:var(--font-heading);font-size:38px;font-weight:700;color:var(--color-accent);margin:0 0 6px;line-height:1}.home-subtitle{font-family:var(--font-ui);font-size:13px;color:var(--color-text-secondary);margin:0;letter-spacing:.08em;text-transform:uppercase}.home-welcome{font-family:var(--font-ui);font-size:15px;color:var(--color-text-secondary)}.home-welcome strong{color:var(--color-text-primary)}.home-stats{display:flex;gap:20px;background:var(--color-surface-raised);border:1px solid var(--color-border);border-radius:var(--radius-surface);padding:16px 24px;width:100%;max-width:360px;box-sizing:border-box}.home-stat{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px}.home-stat-value{font-family:var(--font-heading);font-size:22px;font-weight:700;color:var(--color-text-primary)}.home-stat-label{font-size:10px;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.06em}.home-actions{display:flex;flex-direction:column;gap:12px;width:100%;max-width:320px}.btn-large{padding:14px 20px;font-size:16px;border-radius:10px}.draw-mode-toggle{display:flex;gap:0;background:var(--color-surface-raised);border:1px solid var(--color-border);border-radius:20px;padding:3px;align-self:center}.draw-mode-pill{flex:1;padding:7px 20px;border-radius:16px;border:none;background:transparent;color:var(--color-text-secondary);font-family:var(--font-ui);font-size:13px;font-weight:500;cursor:pointer;transition:background .15s,color .15s}.draw-mode-pill--active{background:var(--color-accent);color:#1a1a1a;font-weight:700}.draw-mode-pill:not(.draw-mode-pill--active):hover{color:var(--color-text-primary)}.card-wrap{position:relative;width:var(--card-w, 62px);height:var(--card-h, 88px);flex-shrink:0;cursor:pointer;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent}.card-face{width:100%;height:100%;border-radius:var(--radius-card);background:var(--color-card-face);box-shadow:var(--shadow-card);border:1px solid rgba(0,0,0,.1);display:flex;flex-direction:column;justify-content:space-between;padding:3px 4px;box-sizing:border-box;transition:transform .1s ease,box-shadow .1s ease;position:relative;overflow:hidden}.card-face.red{color:var(--color-suit-red)}.card-face.black{color:var(--color-suit-black)}.card-face.selected{transform:translateY(-4px);box-shadow:0 0 0 2px var(--color-accent),var(--shadow-card)}.card-corner{display:flex;flex-direction:column;align-items:center;line-height:1}.card-corner.bottom{transform:rotate(180deg);align-self:flex-end}.card-rank{font-family:var(--font-heading);font-size:14px;font-weight:700;line-height:1}.card-suit-small{font-size:10px;line-height:1}.card-suit-center{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:28px;opacity:.15;pointer-events:none}.card-back{width:100%;height:100%;border-radius:var(--radius-card);background-color:var(--color-card-back);background-image:var(--card-back-image, none);background-size:40px 40px;background-repeat:repeat;box-shadow:var(--shadow-card);border:1px solid rgba(255,255,255,.06);box-sizing:border-box;overflow:hidden;position:relative}.card-back:after{content:"";position:absolute;top:4px;right:4px;bottom:4px;left:4px;border-radius:calc(var(--radius-card) - 2px);border:1.5px solid var(--color-accent);opacity:.4;background:repeating-linear-gradient(45deg,transparent,transparent 4px,rgba(201,168,76,.06) 4px,rgba(201,168,76,.06) 8px)}.card-back.has-pattern:after{background:none}.card-face--classic{justify-content:space-between}.card-classic-center{display:flex;flex-direction:column;align-items:center;justify-content:center;flex:1;gap:2px}.card-classic-rank{font-family:var(--font-heading);font-size:20px;font-weight:700;line-height:1}.card-classic-suit{font-size:16px;line-height:1}.card-face--minimal{justify-content:center;align-items:center;position:relative}.card-minimal-suit-indicator{position:absolute;top:4px;right:5px;font-size:9px;line-height:1;opacity:.8}.card-minimal-rank{font-family:var(--font-heading);font-size:26px;font-weight:700;line-height:1}.card-slot{width:var(--card-w, 62px);height:var(--card-h, 88px);border-radius:var(--radius-card);border:1.5px dashed var(--color-border);box-sizing:border-box;flex-shrink:0;cursor:pointer}:root{--card-w: 52px;--card-h: 74px;--tableau-offset: 18px;--tableau-offset-up: 26px}@media (max-width: 359px){:root{--card-w: 44px;--card-h: 62px;--tableau-offset: 14px;--tableau-offset-up: 20px}}@media (min-width: 480px) and (max-width: 599px){:root{--card-w: 62px;--card-h: 88px;--tableau-offset: 20px;--tableau-offset-up: 30px}}@media (min-width: 600px){:root{--card-w: 72px;--card-h: 100px;--tableau-offset: 22px;--tableau-offset-up: 32px}}.board{display:flex;flex-direction:column;gap:10px;padding:10px 8px;min-height:100%;box-sizing:border-box;touch-action:none}.tableau-card,.waste-card,.stock-pile{touch-action:none}.board-top{display:flex;align-items:flex-start;gap:clamp(3px,1.2vw,8px)}.board-top-spacer{flex:1}.stock-pile{position:relative;width:var(--card-w);height:var(--card-h);border-radius:var(--radius-card);cursor:pointer;flex-shrink:0}.stock-empty{width:var(--card-w);height:var(--card-h);border-radius:var(--radius-card);border:1.5px dashed var(--color-border);display:flex;align-items:center;justify-content:center;color:var(--color-text-secondary);font-size:20px;cursor:pointer;flex-shrink:0}.waste-area{position:relative;width:calc(var(--card-w) + 24px);height:var(--card-h);flex-shrink:0}.waste-card{position:absolute;top:0}.foundation-pile{position:relative;width:var(--card-w);height:var(--card-h);flex-shrink:0;cursor:pointer}.foundation-empty{width:100%;height:100%;border-radius:var(--radius-card);border:1.5px dashed var(--color-border);display:flex;align-items:center;justify-content:center;color:var(--color-border);font-size:22px}.foundation-top{position:absolute;top:0;left:0;width:100%;height:100%}.board-tableau{display:flex;gap:clamp(3px,1.2vw,8px);align-items:flex-start;flex:1}.tableau-col{flex:1;min-width:0;position:relative;display:flex;flex-direction:column}.tableau-col-empty{width:100%;height:var(--card-h);border-radius:var(--radius-card);border:1.5px dashed var(--color-border);cursor:pointer}.tableau-card{position:relative;flex-shrink:0}.tableau-card+.tableau-card{margin-top:calc(-1 * var(--card-h) + var(--tableau-offset))}.tableau-card.face-up+.tableau-card{margin-top:calc(-1 * var(--card-h) + var(--tableau-offset-up))}.dragging{opacity:.5}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-4px)}75%{transform:translate(4px)}}.shake{animation:shake .4s ease}.board-stats{display:flex;justify-content:space-between;align-items:center;padding:4px 2px;font-family:var(--font-ui);font-size:13px;color:var(--color-text-secondary)}.board-stats span{min-width:60px;text-align:center}.autocomplete-btn{background:var(--color-accent);color:#000;border:none;border-radius:6px;padding:5px 12px;font-family:var(--font-ui);font-size:12px;font-weight:700;cursor:pointer;transition:background .15s;white-space:nowrap}.autocomplete-btn:hover{background:var(--color-accent-hover)}.win-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:200;animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.win-modal{background:var(--color-surface-raised);border:1px solid var(--color-border);border-radius:var(--radius-surface);box-shadow:var(--shadow-surface);padding:32px 28px;width:min(360px,90vw);display:flex;flex-direction:column;align-items:center;gap:20px;animation:slideUp .35s cubic-bezier(.34,1.56,.64,1)}@keyframes slideUp{0%{transform:translateY(40px);opacity:0}to{transform:translateY(0);opacity:1}}.win-trophy{font-size:56px;line-height:1}.win-title{font-family:var(--font-heading);font-size:28px;color:var(--color-accent);margin:0;text-align:center}.win-stats{display:flex;gap:24px}.win-stat{display:flex;flex-direction:column;align-items:center;gap:4px;font-family:var(--font-ui)}.win-stat-value{font-size:24px;font-weight:700;color:var(--color-text-primary)}.win-stat-label{font-size:11px;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.05em}.win-buttons{display:flex;flex-direction:column;gap:10px;width:100%}.btn-primary{background:var(--color-accent);color:#000;border:none;border-radius:8px;padding:12px 20px;font-family:var(--font-ui);font-size:15px;font-weight:600;cursor:pointer;transition:background .15s ease;width:100%}.btn-primary:hover{background:var(--color-accent-hover)}.btn-secondary{background:transparent;color:var(--color-text-secondary);border:1px solid var(--color-border);border-radius:8px;padding:10px 20px;font-family:var(--font-ui);font-size:14px;cursor:pointer;transition:color .15s,border-color .15s;width:100%}.btn-secondary:hover{color:var(--color-text-primary);border-color:var(--color-text-secondary)}.game-screen{padding:0;overflow-y:auto;-webkit-overflow-scrolling:touch}.game-center{display:flex;align-items:center;justify-content:center;flex-direction:column;gap:16px;color:var(--color-text-secondary);font-family:var(--font-ui)}.game-spinner{font-family:var(--font-heading);font-size:20px;color:var(--color-accent);animation:pulse 1.2s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.resume-prompt{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-surface);padding:32px 28px;display:flex;flex-direction:column;align-items:center;gap:20px;width:min(320px,90vw)}.resume-prompt-text{font-family:var(--font-heading);font-size:18px;color:var(--color-text-primary);margin:0;text-align:center}.resume-prompt-buttons{display:flex;flex-direction:column;gap:10px;width:100%}.daily-screen{display:flex;flex-direction:column;padding:0;overflow:hidden}.daily-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px 8px;border-bottom:1px solid var(--color-border);flex-shrink:0}.daily-title{font-family:var(--font-heading);font-size:20px;color:var(--color-accent);margin:0 0 2px}.daily-date{font-family:var(--font-ui);font-size:12px;color:var(--color-text-secondary);margin:0}.daily-tabs{display:flex;gap:4px}.daily-tab{background:none;border:1px solid var(--color-border);color:var(--color-text-secondary);border-radius:6px;padding:5px 12px;font-size:13px;cursor:pointer;font-family:var(--font-ui);transition:all .15s}.daily-tab.active{background:var(--color-accent-muted);border-color:var(--color-accent);color:var(--color-accent)}.leaderboard{flex:1;overflow-y:auto;padding:12px 16px;display:flex;flex-direction:column;gap:12px}.my-rank-bar{background:var(--color-accent-muted);border:1px solid var(--color-accent);border-radius:8px;padding:10px 14px;font-family:var(--font-ui);font-size:14px;color:var(--color-text-primary)}.sort-row{display:flex;align-items:center;gap:8px;font-family:var(--font-ui);font-size:13px;color:var(--color-text-secondary)}.sort-btn{background:none;border:1px solid var(--color-border);color:var(--color-text-secondary);border-radius:5px;padding:4px 10px;font-size:12px;cursor:pointer;font-family:var(--font-ui)}.sort-btn.active{border-color:var(--color-accent);color:var(--color-accent)}.lb-empty{text-align:center;color:var(--color-text-secondary);padding:24px!important}.daily-loading{display:flex;align-items:center;justify-content:center;min-height:200px;color:var(--color-text-secondary);font-size:15px}.daily-unavailable{display:flex;align-items:center;justify-content:center;min-height:300px;padding:24px}.daily-unavailable-box{background:var(--color-surface);border:1px solid var(--color-border);border-radius:16px;padding:40px 32px;text-align:center;max-width:340px;width:100%}.daily-unavailable-icon{font-size:48px;margin-bottom:16px}.daily-unavailable-title{font-size:18px;font-weight:700;color:var(--color-text-primary);margin:0 0 10px}.daily-unavailable-body{font-size:14px;color:var(--color-text-secondary);line-height:1.5;margin:0 0 24px}.daily-unavailable-btn{background:var(--color-accent);color:#000;border:none;border-radius:8px;padding:12px 28px;font-size:15px;font-weight:600;cursor:pointer;transition:opacity .15s}.daily-unavailable-btn:hover{opacity:.85}.friends-screen{display:flex;flex-direction:column;padding:0;overflow:hidden}.friends-center{align-items:center;justify-content:center;color:var(--color-text-secondary);font-family:var(--font-ui)}.tab-bar{display:flex;border-bottom:1px solid var(--color-border);flex-shrink:0}.tab-btn{flex:1;background:none;border:none;padding:12px 8px;font-family:var(--font-ui);font-size:14px;color:var(--color-text-secondary);cursor:pointer;position:relative;transition:color .15s}.tab-btn.active{color:var(--color-accent);border-bottom:2px solid var(--color-accent)}.badge{background:var(--color-danger);color:#fff;border-radius:10px;font-size:10px;padding:1px 5px;margin-left:4px;vertical-align:middle}.tab-content{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:12px}.invite-btn{align-self:flex-start}.invite-link-box{background:var(--color-surface-raised);border:1px solid var(--color-border);border-radius:8px;padding:12px}.invite-label{font-size:12px;color:var(--color-text-secondary);margin:0 0 8px;font-family:var(--font-ui)}.invite-link-row{display:flex;align-items:flex-start;gap:10px}.invite-link{flex:1;font-size:11px;color:var(--color-accent);word-break:break-all;font-family:monospace;line-height:1.5}.invite-actions{display:flex;flex-direction:column;gap:6px;flex-shrink:0}.invite-action-btn{display:flex;align-items:center;gap:5px;background:none;border:1px solid var(--color-border);border-radius:6px;padding:5px 10px;color:var(--color-text-secondary);cursor:pointer;font-family:var(--font-ui);font-size:12px;text-decoration:none;white-space:nowrap;transition:color .15s,border-color .15s}.invite-action-btn:hover{color:var(--color-accent);border-color:var(--color-accent)}.invite-action-btn.copied{color:#4caf7d;border-color:#4caf7d}.invite-action-label{font-size:12px}.friends-list{display:flex;flex-direction:column;gap:8px}.friend-row{display:flex;align-items:center;justify-content:space-between;padding:12px;background:var(--color-surface-raised);border:1px solid var(--color-border);border-radius:8px}.friend-info{display:flex;flex-direction:column;gap:2px}.friend-name{font-family:var(--font-ui);font-size:15px;color:var(--color-text-primary);font-weight:500}.friend-stat{font-size:12px;color:var(--color-text-secondary);font-family:var(--font-ui)}.btn-danger-sm{background:none;border:1px solid var(--color-danger);color:var(--color-danger);border-radius:6px;padding:4px 10px;font-size:12px;cursor:pointer;font-family:var(--font-ui)}.period-toggle{display:flex;gap:6px}.period-btn{background:none;border:1px solid var(--color-border);color:var(--color-text-secondary);border-radius:6px;padding:5px 12px;font-size:13px;cursor:pointer;font-family:var(--font-ui)}.period-btn.active{border-color:var(--color-accent);color:var(--color-accent)}.lb-table{width:100%;border-collapse:collapse;font-family:var(--font-ui);font-size:14px}.lb-table th{text-align:left;padding:6px 8px;color:var(--color-text-secondary);font-size:11px;text-transform:uppercase;letter-spacing:.06em;border-bottom:1px solid var(--color-border)}.lb-table td{padding:10px 8px;color:var(--color-text-primary);border-bottom:1px solid var(--color-border)}.lb-table tr.lb-me td{background:var(--color-accent-muted);color:var(--color-accent);font-weight:600}.lb-empty,.empty-state{text-align:center;color:var(--color-text-secondary);padding:24px 0;font-family:var(--font-ui);font-size:14px}.challenge-row{display:flex;align-items:center;justify-content:space-between;padding:12px;background:var(--color-surface-raised);border:1px solid var(--color-border);border-radius:8px;font-family:var(--font-ui);font-size:14px;color:var(--color-text-primary)}.challenge-stat{font-size:12px;color:var(--color-text-secondary);margin-top:3px}.calendar{width:100%;-webkit-user-select:none;user-select:none}.calendar-nav{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.calendar-nav-title{font-family:var(--font-ui);font-size:15px;font-weight:600;color:var(--color-text-primary);letter-spacing:.01em;min-width:140px;text-align:center}.calendar-nav-side{display:flex;gap:2px}.cal-nav-btn{background:var(--color-surface-raised);border:1px solid var(--color-border);border-radius:6px;color:var(--color-text-primary);font-size:16px;line-height:1;width:30px;height:30px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .12s,opacity .12s;padding:0}.cal-nav-btn:hover:not(:disabled){background:var(--color-accent-muted);color:var(--color-accent)}.cal-nav-btn:disabled{opacity:.25;cursor:default}.calendar-row{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;margin-bottom:4px}.calendar-header-row{margin-bottom:6px}.calendar-header-cell{font-family:var(--font-ui);font-size:10px;color:var(--color-text-secondary);text-align:center;text-transform:uppercase;letter-spacing:.05em;padding:2px 0}.calendar-cell{aspect-ratio:1;border-radius:6px;background:var(--color-surface-raised);border:1px solid transparent;cursor:pointer;position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;transition:background .1s,transform .1s}.calendar-cell--empty{background:transparent;border-color:transparent;cursor:default;pointer-events:none}.calendar-cell--played{background:color-mix(in srgb,var(--color-accent) calc(var(--cell-opacity, .35) * 100%),var(--color-surface-raised))}@supports not (background: color-mix(in srgb,red 30%,blue)){.calendar-cell--played{background:var(--color-surface-raised)}.calendar-cell--played:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:6px;background:var(--color-accent);opacity:var(--cell-opacity, .35);pointer-events:none}}.calendar-cell--won{border-color:var(--color-accent)}.calendar-cell--today .calendar-day-num{color:var(--color-accent);font-weight:700}.calendar-cell--future{opacity:.3;cursor:default}.calendar-cell:not(.calendar-cell--future):not(.calendar-cell--empty):hover{transform:scale(1.08);z-index:2;background:var(--color-accent-muted)}.calendar-day-num{font-family:var(--font-ui);font-size:12px;font-weight:500;color:var(--color-text-primary);line-height:1}.calendar-dot-row{display:flex;gap:2px;align-items:center}.calendar-dot{width:4px;height:4px;border-radius:50%}.calendar-dot--win{background:var(--color-accent)}.calendar-dot--play{background:var(--color-text-secondary);opacity:.6}.day-detail-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;z-index:1000;display:flex;align-items:flex-end;justify-content:center}.day-detail-drawer{width:100%;max-width:480px;background:var(--color-surface);border-radius:16px 16px 0 0;border-top:1px solid var(--color-border);padding:0 0 env(safe-area-inset-bottom,0);animation:drawerSlideUp .25s ease-out;max-height:75vh;display:flex;flex-direction:column}.day-detail-drawer--detail{max-height:82vh}@keyframes drawerSlideUp{0%{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}.day-detail-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px 12px;border-bottom:1px solid var(--color-border);flex-shrink:0;gap:8px}.day-detail-title{font-family:var(--font-heading);font-size:18px;color:var(--color-accent);margin:0;flex:1}.day-detail-mode-title{font-family:var(--font-ui);font-size:15px;font-weight:600;color:var(--color-text-primary);flex:1;text-align:center}.day-detail-close{background:none;border:none;color:var(--color-text-secondary);font-size:22px;line-height:1;cursor:pointer;padding:2px 6px;border-radius:6px;transition:color .15s,background .15s}.day-detail-close:hover{color:var(--color-text-primary);background:var(--color-surface-raised)}.day-detail-back{background:none;border:none;color:var(--color-accent);font-family:var(--font-ui);font-size:15px;cursor:pointer;padding:2px 0;white-space:nowrap}.day-detail-body{overflow-y:auto;padding:12px 20px 20px;display:flex;flex-direction:column;gap:10px}.day-detail-empty{font-family:var(--font-ui);font-size:14px;color:var(--color-text-secondary);margin:0;padding:8px 0}.day-detail-session{background:var(--color-surface-raised);border:1px solid var(--color-border);border-radius:10px;padding:12px 14px;display:flex;flex-direction:column;gap:6px}.day-detail-session--btn{width:100%;text-align:left;cursor:pointer;transition:border-color .15s,background .15s}.day-detail-session--btn:hover,.day-detail-session--btn:focus-visible{border-color:var(--color-accent);outline:none}.day-detail-session--won{border-color:#c9a84c59}.day-detail-session-row{display:flex;align-items:center;justify-content:space-between;gap:8px}.day-detail-session-left,.day-detail-session-right{display:flex;align-items:center;gap:8px}.day-detail-session-meta{font-family:var(--font-ui);font-size:12px;color:var(--color-text-secondary)}.day-detail-session-time{font-family:var(--font-ui);font-size:13px;font-weight:600;color:var(--color-text-primary)}.day-detail-mode-badge{font-family:var(--font-ui);font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-secondary);background:var(--color-surface);border:1px solid var(--color-border);border-radius:4px;padding:1px 5px}.day-detail-status{font-family:var(--font-ui);font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;padding:2px 8px;border-radius:20px}.day-detail-status--won,.day-detail-status--complete{color:var(--color-accent);background:var(--color-accent-muted)}.day-detail-status--abandoned{color:var(--color-text-secondary);background:var(--color-surface)}.day-detail-status--active{color:#3b82f6;background:#3b82f61f}.day-detail-solved-badge{display:flex;align-items:center;gap:3px;font-family:var(--font-ui);font-size:11px;color:var(--color-text-secondary);background:var(--color-surface);border:1px solid var(--color-border);border-radius:20px;padding:2px 7px 2px 5px}.day-detail-solved-icon{color:var(--color-text-secondary)}.day-detail-chevron{margin-left:auto;color:var(--color-text-secondary);font-size:16px;line-height:1}.day-detail-replay-btn{width:100%;padding:13px;font-size:15px;letter-spacing:.02em}.day-detail-your-result{display:flex;align-items:center;gap:8px;flex-wrap:wrap;background:var(--color-surface-raised);border:1px solid var(--color-border);border-radius:8px;padding:10px 14px;font-family:var(--font-ui);font-size:13px}.day-detail-your-label{color:var(--color-text-secondary);font-size:12px;margin-right:4px}.day-detail-your-stat{color:var(--color-text-primary)}.day-detail-your-sep{color:var(--color-text-secondary)}.day-detail-your-rank{margin-left:auto;font-weight:700;color:var(--color-accent);font-size:15px}.day-detail-lb-header{display:flex;align-items:center;gap:7px;font-family:var(--font-ui);font-size:13px;font-weight:600;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.06em}.day-detail-lb-trophy{color:var(--color-accent)}.day-detail-lb-table{width:100%;border-collapse:collapse;font-family:var(--font-ui);font-size:14px}.day-detail-lb-table th{text-align:left;padding:5px 8px;color:var(--color-text-secondary);font-size:11px;text-transform:uppercase;letter-spacing:.06em;border-bottom:1px solid var(--color-border)}.day-detail-lb-table td{padding:9px 8px;color:var(--color-text-primary);border-bottom:1px solid var(--color-border)}.day-detail-lb-table tr.day-detail-lb-me td{background:var(--color-accent-muted);color:var(--color-accent);font-weight:600}.profile-screen{padding:20px 16px;display:flex;flex-direction:column;gap:24px;overflow-y:auto}.section-title{font-family:var(--font-heading);font-size:24px;color:var(--color-accent);margin:0}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}@media (max-width: 360px){.stats-grid{grid-template-columns:repeat(2,1fr)}}.stat-card{background:var(--color-surface-raised);border:1px solid var(--color-border);border-radius:10px;padding:12px 8px;display:flex;flex-direction:column;align-items:center;gap:4px}.stat-card-value{font-family:var(--font-heading);font-size:20px;font-weight:700;color:var(--color-text-primary)}.stat-card-label{font-size:9px;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.05em;text-align:center}.stats-mode-label{font-family:var(--font-ui);font-size:12px;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.05em;margin:0 0 6px}.stats-mode-block+.stats-mode-block{margin-top:12px}.records-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}.record-card{background:var(--color-surface-raised);border:1px solid var(--color-border);border-radius:10px;padding:14px 10px;display:flex;flex-direction:column;align-items:center;gap:4px}.record-card-value{font-family:var(--font-heading);font-size:22px;font-weight:700;color:var(--color-accent)}.record-card-label{font-size:9px;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.05em;text-align:center}.record-card-meta{font-size:11px;color:var(--color-text-secondary);text-align:center}.profile-section{display:flex;flex-direction:column;gap:10px}.profile-section-title{font-family:var(--font-ui);font-size:13px;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.06em;margin:0}.name-row{display:flex;gap:8px}.login-form{display:flex;flex-direction:column;gap:12px;max-width:300px}.text-input{background:var(--color-surface-raised);border:1px solid var(--color-border);border-radius:8px;padding:10px 12px;font-family:var(--font-ui);font-size:15px;color:var(--color-text-primary);flex:1;outline:none;transition:border-color .15s}.text-input:focus{border-color:var(--color-accent)}.login-note{font-family:var(--font-ui);font-size:13px;color:var(--color-text-secondary);margin:0}.error-text{color:var(--color-danger);font-size:13px;margin:0}.settings-screen{padding:20px 16px;display:flex;flex-direction:column;gap:28px;overflow-y:auto}.settings-section{display:flex;flex-direction:column;gap:12px}.settings-section-title{font-family:var(--font-ui);font-size:12px;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.08em;margin:0}.theme-grid{display:flex;gap:12px}.theme-card{flex:1;border-radius:12px;border:2px solid transparent;padding:12px;cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:8px;transition:border-color .2s,transform .15s;position:relative}.theme-card:hover{transform:translateY(-2px)}.theme-preview{width:44px;height:60px;border-radius:6px;border:1.5px solid;display:flex;align-items:center;justify-content:center;font-family:var(--font-heading);font-size:13px;font-weight:700}.theme-label{font-family:var(--font-ui);font-size:11px;font-weight:500;text-align:center}.theme-check{position:absolute;top:6px;right:8px;font-size:14px;font-weight:700}.pill-toggle{display:flex;gap:0;background:var(--color-surface-raised);border:1px solid var(--color-border);border-radius:20px;padding:3px;align-self:flex-start}.pill-btn{padding:7px 20px;border-radius:16px;border:none;background:transparent;color:var(--color-text-secondary);font-family:var(--font-ui);font-size:13px;font-weight:500;cursor:pointer;transition:background .15s,color .15s}.pill-btn--active{background:var(--color-accent);color:#1a1a1a;font-weight:700}.pill-btn:not(.pill-btn--active):hover{color:var(--color-text-primary)}.design-cards{display:flex;gap:12px}.design-card{flex:1;display:flex;flex-direction:column;align-items:center;gap:8px;cursor:pointer;padding:10px 8px;border-radius:10px;border:2px solid var(--color-border);background:var(--color-surface-raised);transition:border-color .15s,transform .15s}.design-card:hover{transform:translateY(-2px)}.design-card--active{border-color:var(--color-accent)}.design-card-preview{width:40px;height:56px;border-radius:5px;background:var(--color-card-face);border:1px solid var(--color-border);display:flex;align-items:center;justify-content:center;flex-direction:column;gap:2px;position:relative}.design-card-suit{font-size:16px;color:var(--color-suit-black)}.design-card-rank{font-family:var(--font-heading);font-size:13px;font-weight:700;color:var(--color-suit-black)}.design-card-label{font-family:var(--font-ui);font-size:11px;color:var(--color-text-secondary);text-align:center}.pattern-grid{display:flex;gap:12px}.pattern-tile{flex:1;position:relative;height:80px;border-radius:8px;border:2px solid transparent;cursor:pointer;padding:0;overflow:hidden;transition:border-color .15s,transform .15s;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;background-color:#1c2333}.pattern-tile:hover{transform:translateY(-2px)}.pattern-tile--active{box-shadow:0 0 0 1px var(--color-accent)}.pattern-tile-check{position:absolute;top:6px;right:8px;font-size:13px;font-weight:700;text-shadow:0 1px 3px rgba(0,0,0,.6)}.pattern-tile-label{font-family:var(--font-ui);font-size:10px;font-weight:500;color:#ffffffd9;text-shadow:0 1px 3px rgba(0,0,0,.7);padding:4px 0 5px;background:#00000059;width:100%;text-align:center;letter-spacing:.04em}.settings-subsection-label{font-family:var(--font-ui);font-size:11px;color:var(--color-text-secondary);margin:4px 0 0}.swatch-row{display:flex;flex-direction:row;gap:10px;flex-wrap:wrap}.swatch{width:32px;height:32px;border-radius:6px;cursor:pointer;border:2px solid transparent;padding:0;outline:none;transition:transform .12s,border-color .12s}.swatch:hover{transform:scale(1.1)}.swatch.active{border-color:var(--color-accent)}.toggle-row{display:flex;flex-direction:row;align-items:center;gap:12px}.toggle-label{font-family:var(--font-ui);font-size:14px;color:var(--color-text-primary);min-width:24px}.toggle{position:relative;display:inline-block;width:48px;height:28px;cursor:pointer}.toggle input{opacity:0;width:0;height:0;position:absolute}.toggle-track{position:absolute;top:0;right:0;bottom:0;left:0;background:var(--color-surface-raised);border:1px solid var(--color-border);border-radius:14px;transition:background .2s}.toggle-track:before{content:"";position:absolute;top:3px;left:3px;width:20px;height:20px;border-radius:50%;background:var(--color-text-secondary);transition:transform .2s,background .2s}.toggle input:checked+.toggle-track{background:var(--color-accent-muted);border-color:var(--color-accent)}.toggle input:checked+.toggle-track:before{transform:translate(20px);background:var(--color-accent)}.draw-mode-box{background:var(--color-surface-raised);border:1px solid var(--color-border);border-radius:10px;padding:14px 16px}.draw-mode-text{font-family:var(--font-ui);font-size:15px;font-weight:600;color:var(--color-text-primary);margin:0 0 6px}.draw-mode-note{font-family:var(--font-ui);font-size:13px;color:var(--color-text-secondary);margin:0;line-height:1.5}.about-text{font-family:var(--font-ui);font-size:13px;color:var(--color-text-secondary);margin:0;line-height:1.6}.accept-invite-screen{display:flex;align-items:center;justify-content:center;min-height:100vh;background:var(--color-table);padding:24px;box-sizing:border-box}.accept-invite-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:16px;padding:40px 32px;text-align:center;max-width:360px;width:100%}.accept-invite-icon{font-size:48px;margin-bottom:16px}.accept-invite-title{font-family:var(--font-ui);font-size:22px;font-weight:700;color:var(--color-text-primary);margin:0 0 12px}.accept-invite-msg{font-family:var(--font-ui);font-size:15px;color:var(--color-text-secondary);line-height:1.5;margin:0 0 24px}.accept-invite-msg.error{color:#e57373}.accept-invite-btn{background:var(--color-accent);color:#000;border:none;border-radius:8px;padding:12px 32px;font-family:var(--font-ui);font-size:15px;font-weight:600;cursor:pointer;transition:opacity .15s;width:100%}.accept-invite-btn:hover{opacity:.85}.login-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--color-table);padding:24px 16px;box-sizing:border-box}.login-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-surface);box-shadow:var(--shadow-surface);padding:40px 32px;width:min(400px,100%);display:flex;flex-direction:column;align-items:center;gap:0}.login-heading{font-family:var(--font-heading);font-size:32px;font-weight:700;color:var(--color-accent);margin:0 0 6px;text-align:center;letter-spacing:.01em}.login-subtitle{font-family:var(--font-ui);font-size:13px;color:var(--color-text-secondary);margin:0 0 28px;text-align:center}.login-tabs{display:flex;width:100%;border:1px solid var(--color-border);border-radius:8px;overflow:hidden;margin-bottom:28px}.login-tab{flex:1;padding:10px 0;background:transparent;border:none;color:var(--color-text-secondary);font-family:var(--font-ui);font-size:14px;font-weight:500;cursor:pointer;transition:background .15s,color .15s}.login-tab.active{background:var(--color-accent-muted);color:var(--color-accent)}.login-tab:hover:not(.active){background:#ffffff0a;color:var(--color-text-primary)}.login-form{width:100%;display:flex;flex-direction:column;gap:18px}.login-field{display:flex;flex-direction:column;gap:6px}.login-label{font-family:var(--font-ui);font-size:12px;font-weight:600;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.06em}.login-input{width:100%;padding:11px 14px;background:var(--color-surface-raised);border:1px solid var(--color-border);border-radius:8px;color:var(--color-text-primary);font-family:var(--font-ui);font-size:15px;box-sizing:border-box;transition:border-color .15s;outline:none}.login-input::placeholder{color:var(--color-text-secondary);opacity:.6}.login-input:focus{border-color:var(--color-accent)}.login-input:disabled{opacity:.5}.login-error{background:#f851491f;border:1px solid rgba(248,81,73,.3);border-radius:6px;color:var(--color-danger);font-family:var(--font-ui);font-size:13px;padding:10px 14px;margin:0;text-align:center}.login-submit{width:100%;padding:13px 20px;background:var(--color-accent);color:#000;border:none;border-radius:8px;font-family:var(--font-ui);font-size:15px;font-weight:700;cursor:pointer;transition:background .15s;margin-top:4px}.login-submit:hover:not(:disabled){background:var(--color-accent-hover)}.login-submit:disabled{opacity:.55;cursor:not-allowed}:root{--color-table: #0d1117;--color-surface: #161b22;--color-surface-raised: #1c2333;--color-card-face: #f8f9fa;--color-card-back: #1c2333;--color-accent: #c9a84c;--color-accent-hover: #e2c06a;--color-accent-muted: rgba(201,168,76,.15);--color-suit-red: #e05c5c;--color-suit-black: #1a1a1a;--color-text-primary: #e6edf3;--color-text-secondary: #8b949e;--color-border: rgba(255,255,255,.08);--color-danger: #f85149;--shadow-card: 0 4px 24px rgba(0,0,0,.6);--shadow-surface: 0 2px 12px rgba(0,0,0,.4);--radius-card: 8px;--radius-surface: 12px;--font-heading: "Playfair Display", Georgia, serif;--font-ui: "Inter", system-ui, sans-serif}html.theme-classic{--color-table: #1a5c2e;--color-surface: #0d3d1e;--color-surface-raised: #1a5c2e;--color-card-face: #fffef5;--color-card-back: #8b1a1a;--color-accent: #f5c518;--color-accent-hover: #f7d152;--color-accent-muted: rgba(245,197,24,.15);--color-suit-red: #cc2222;--color-suit-black: #1a1a1a;--color-text-primary: #f0ead6;--color-text-secondary: #b0a070;--color-border: rgba(255,255,255,.12);--shadow-card: 0 2px 12px rgba(0,0,0,.5);--shadow-surface: 0 2px 8px rgba(0,0,0,.4)}html.theme-modern{--color-table: #e8eaed;--color-surface: #ffffff;--color-surface-raised: #f3f4f6;--color-card-face: #ffffff;--color-card-back: #4a5568;--color-accent: #2563eb;--color-accent-hover: #3b82f6;--color-accent-muted: rgba(37,99,235,.1);--color-suit-red: #dc2626;--color-suit-black: #1f2937;--color-text-primary: #1f2937;--color-text-secondary: #6b7280;--color-border: rgba(0,0,0,.1);--shadow-card: 0 1px 8px rgba(0,0,0,.15);--shadow-surface: 0 1px 4px rgba(0,0,0,.1)}html.animations-off *{animation-duration:.001ms!important;transition-duration:.001ms!important}
