:root{font-family:Inter,Noto Sans SC,system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;font-feature-settings:"cv11","ss01","ss03";color-scheme:light;line-height:1.5;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-text-size-adjust:100%;--paper: #FAF7F2;--paper-raised: #FFFFFF;--paper-sunken: #F2EDE4;--ink: #1F1B16;--ink-2: #4A4239;--ink-3: #8B7F6F;--ink-4: #B8AC9A;--line: #E8E0D2;--line-strong: #D4C9B5;--clay: #C2410C;--clay-hover: #9A3309;--clay-soft: #FEEDE3;--new: #2563EB;--new-soft: #E6EEFE;--success: #2D7A4F;--warn: #B5651D;--wrong: #B42318}*,*:before,*:after{box-sizing:border-box}html,body{margin:0;padding:0}body{background:var(--paper);color:var(--ink);font-family:Inter,Noto Sans SC,system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;min-height:100vh;-webkit-tap-highlight-color:transparent}#root{width:100%;margin:0 auto;min-height:100vh}h1,h2,h3{font-family:Fraunces,Iowan Old Style,Apple Garamond,Georgia,Times New Roman,serif;font-weight:500;letter-spacing:-.01em;color:var(--ink);margin:0}h1{font-size:clamp(2rem,4vw,2.75rem);line-height:1.1}h2{font-size:1.5rem;line-height:1.2}h3{font-size:1.125rem;line-height:1.3}p{margin:0}a{color:var(--clay);text-decoration:none;transition:color .12s cubic-bezier(.2,.7,.2,1)}a:hover{color:#9a3309}button{font-family:inherit;cursor:pointer}::selection{background:#FEEDE3;color:#7c2a09}:focus-visible{outline:2px solid var(--clay);outline-offset:2px;border-radius:6px}:focus:not(:focus-visible){outline:none}.hairline{border:none;border-top:1px solid var(--line);margin:0}.center{display:flex;align-items:center;justify-content:center;flex-direction:column;width:100vw;height:100vh}.login-form{padding:8px}.login-form .buttons{margin-top:4px}.login-form button{float:right}.home{max-width:760px;margin:0 auto;padding:0 24px 96px}.home__header{display:flex;align-items:flex-end;justify-content:space-between;gap:24px;margin-bottom:48px}.home__header h1{margin:0;font-size:clamp(2rem,4vw,2.5rem);line-height:1.05;letter-spacing:-.015em;font-weight:500}.home__greeting{min-width:0}.home__summary{margin:8px 0 0;color:#8b7f6f;font-size:.95rem}.home__actions{display:flex;align-items:center;gap:8px;flex-shrink:0}.home__actions .create-deck-button-container{position:static;margin:0}.deck-section{margin-bottom:32px}.deck-section__head{display:flex;align-items:baseline;justify-content:space-between;margin:0 4px 12px}.deck-section__title{font-family:Inter,Noto Sans SC,system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;font-size:.75rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:#8b7f6f;margin:0}.deck-section__hint{font-size:.78rem;color:#8b7f6f;font-variant-numeric:tabular-nums}.deck-section__list{background:#FFFFFF;border:1px solid #E8E0D2;border-radius:14px;overflow:hidden;box-shadow:0 1px 2px #1f1b160a,0 1px 1px #1f1b1608}.deck-row{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:16px 24px;cursor:pointer;position:relative;background:#FFFFFF;transition:background .12s cubic-bezier(.2,.7,.2,1)}.deck-row+.deck-row{border-top:1px solid #E8E0D2}.deck-row:hover{background:#F2EDE4}.deck-row:hover .deck-row__chevron{transform:translate(2px);color:#c2410c}.deck-row:hover .deck-row__manage{opacity:1}.deck-row:focus-visible{outline:none;background:#F2EDE4;box-shadow:inset 3px 0 #c2410c}.deck-row.is-empty .deck-row__name{color:#4a4239}.deck-row--skeleton{height:64px;background:linear-gradient(90deg,#F2EDE4 0%,#f4f0e9 50%,#F2EDE4 100%);background-size:200% 100%;animation:deckShimmer 1.4s linear infinite;cursor:default;pointer-events:none}@keyframes deckShimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.deck-row__main{display:flex;flex-direction:column;gap:4px;min-width:0;flex:1}.deck-row__name{font-family:Fraunces,Iowan Old Style,Apple Garamond,Georgia,Times New Roman,serif;font-size:1.15rem;font-weight:500;color:#1f1b16;letter-spacing:-.005em;line-height:1.25;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.deck-row__counts{display:flex;align-items:center;gap:16px;font-size:.85rem;color:#8b7f6f}.count{display:inline-flex;align-items:baseline;gap:6px;font-variant-numeric:tabular-nums}.count__value{font-weight:600;font-size:.95rem}.count__label{color:#8b7f6f}.count--due .count__value{color:#c2410c}.count--new .count__value{color:#2563eb}.count--caught{color:#2d7a4f;font-weight:500;font-size:.85rem}.deck-row__actions{display:flex;align-items:center;gap:12px;flex-shrink:0}.deck-row__manage{font-size:.82rem;font-weight:500;color:#8b7f6f;padding:6px 10px;border-radius:6px;opacity:0;transition:opacity .12s cubic-bezier(.2,.7,.2,1),color .12s cubic-bezier(.2,.7,.2,1),background .12s cubic-bezier(.2,.7,.2,1)}.deck-row__manage:hover{color:#1f1b16;background:#FAF7F2}.deck-row__chevron{font-size:1.1rem;color:#b8ac9a;transition:transform .2s cubic-bezier(.2,.7,.2,1),color .12s cubic-bezier(.2,.7,.2,1);line-height:1;width:1em;text-align:right}@media (hover: none){.deck-row__manage{opacity:1}}.deck-section--strip .deck-section__list{display:none}.caught-strip{list-style:none;margin:0;padding:0;display:flex;flex-wrap:wrap;gap:8px}.caught-strip__item{display:inline-block;padding:6px 12px;border-radius:999px;background:#F2EDE4;color:#4a4239;font-size:.85rem;transition:background .12s cubic-bezier(.2,.7,.2,1),color .12s cubic-bezier(.2,.7,.2,1)}.caught-strip__item:hover{background:#FEEDE3;color:#7c2a09}.home__empty{text-align:center;padding:96px 24px;color:#4a4239}.home__empty p{margin:0;font-family:Fraunces,Iowan Old Style,Apple Garamond,Georgia,Times New Roman,serif;font-size:1.25rem}.home__empty-hint{color:#8b7f6f!important;font-size:1rem!important;margin-top:8px!important;font-style:italic}.home__skeleton{background:#FFFFFF;border:1px solid #E8E0D2;border-radius:14px;overflow:hidden}.home__skeleton .deck-row+.deck-row{border-top:1px solid #E8E0D2}.home__activity{margin-top:64px;padding-top:32px;border-top:1px solid #E8E0D2}.home__activity-head{margin-bottom:16px}.home__activity-head h3{font-family:Inter,Noto Sans SC,system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;font-size:.75rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:#8b7f6f}.home__activity-graph{overflow-x:auto;padding-bottom:8px}@media (max-width: 640px){.home{padding:0 16px 64px}.home__header{flex-direction:column;align-items:stretch;gap:16px}.deck-row{padding:12px 16px}.deck-row__name{font-size:1.05rem}.deck-row__manage{display:none}}.create-deck-button-container{display:inline-flex}.heatmap-scale{display:flex;flex-direction:row;gap:8px;line-height:11px;font-size:.72rem;color:#8b7f6f;align-items:center}.heatmap{color:#4a4239;font-size:.85rem}.heatmap .table-container{overflow-x:auto;padding-bottom:4px}.heatmap .heatmap-row{text-align:left}.heatmap .heatmap-row .weekday-header{font-size:.62rem;color:#8b7f6f;line-height:0px;padding-right:6px}.heatmap .heatmap-row .heatmap-cell-container{padding:2px}.heatmap-cell,.heatmap-scale .heatmap-scale-cell{width:12px;height:12px;border-radius:3px;box-sizing:border-box}.heatmap-cell.color-github-0,.heatmap-scale .color-github-0.heatmap-scale-cell{background:#F2EDE4}.heatmap-cell.color-github-1,.heatmap-scale .color-github-1.heatmap-scale-cell{background:#fef0e8}.heatmap-cell.color-github-2,.heatmap-scale .color-github-2.heatmap-scale-cell{background:#F8C9A8}.heatmap-cell.color-github-3,.heatmap-scale .color-github-3.heatmap-scale-cell{background:#ED8A4A}.heatmap-cell.color-github-4,.heatmap-scale .color-github-4.heatmap-scale-cell{background:#C2410C}.panna-nav{position:sticky;top:0;z-index:50;background:rgba(250,247,242,.85);backdrop-filter:saturate(180%) blur(12px);-webkit-backdrop-filter:saturate(180%) blur(12px);border-bottom:1px solid #E8E0D2;margin-bottom:48px}.panna-nav--flush{margin-bottom:0}.panna-nav__inner{max-width:1080px;margin:0 auto;height:56px;padding:0 24px;display:flex;align-items:center;justify-content:space-between;gap:24px}.panna-nav__brand{font-family:Fraunces,Iowan Old Style,Apple Garamond,Georgia,Times New Roman,serif;font-size:1.125rem;font-weight:500;color:#1f1b16;letter-spacing:-.01em;display:inline-flex;align-items:center;gap:8px}.panna-nav__brand:hover{color:#1f1b16}.panna-nav__brand-mark{width:10px;height:10px;border-radius:999px;background:#C2410C;display:inline-block}.panna-nav__links{list-style:none;margin:0;padding:0;display:flex;align-items:center;gap:4px}.panna-nav__link{display:inline-block;padding:8px 12px;border-radius:6px;font-size:.9rem;font-weight:500;color:#4a4239;transition:background .12s cubic-bezier(.2,.7,.2,1),color .12s cubic-bezier(.2,.7,.2,1)}.panna-nav__link:hover{background:#F2EDE4;color:#1f1b16}.panna-nav__link.is-active{color:#1f1b16;background:#F2EDE4}@media (max-width: 640px){.panna-nav__inner{padding:0 16px}.panna-nav__link{padding:8px;font-size:.85rem}}.deck-view .tabs{display:flex;justify-content:center;flex-direction:row}.cards-container{display:flex;align-items:center;justify-content:center;flex-direction:column;width:100%;height:100%}.cards-container .table-cell{border:none}.cards-container .table-row:hover{background:rgb(38,38,38)}.edit-deck-container{display:flex;flex-direction:row;align-items:flex-start;height:100%}.edit-deck-container .section{padding:16px}.nav-container{position:fixed}.nav-container nav{position:fixed;margin-top:10%;margin-left:20%}th,tr,td{font-size:1.5rem}.deck-view nav{margin-left:25%}@media screen and (max-width: 750px){.deck-view nav{margin-left:0}}canvas.fireworks{position:fixed;pointer-events:none;top:0%}.drafts .table-cell{border:none}.drafts .table-row:hover{background:rgb(68,68,68)}.stats .pie-container{width:300px;height:300px;margin:auto}.stats .today-container{width:300px;margin:auto;padding:8px}.stats .today-container h3{margin:8px 0}div.editor{min-height:200px;width:600px;margin:16px auto auto;padding:8px}@media screen and (max-width: 768px){div.editor{width:80%}}div.editor:empty{border:1px solid rgba(144,202,249,.5)}div.editor span,div.editor .highlight{display:inline-block;background-color:#ff0}.rv{min-height:100vh;background:#FAF7F2;display:flex;flex-direction:column}.rv-topbar{position:sticky;top:0;z-index:10;background:rgba(250,247,242,.9);backdrop-filter:saturate(180%) blur(12px);-webkit-backdrop-filter:saturate(180%) blur(12px);border-bottom:1px solid #E8E0D2}.rv-topbar__inner{max-width:880px;margin:0 auto;height:56px;padding:0 16px;display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:12px}.rv-topbar__center{display:flex;align-items:center;justify-content:center;min-width:0}.rv-topbar__deck{font-family:Fraunces,Iowan Old Style,Apple Garamond,Georgia,Times New Roman,serif;font-size:1rem;color:#4a4239;font-style:italic;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.rv-topbar__actions{display:flex;align-items:center;justify-content:flex-end;gap:2px}.rv-topbar__actions .MuiButton-root{min-width:0;width:34px;height:34px;padding:0;border-radius:6px;color:#4a4239}.rv-topbar__actions .MuiButton-root:hover{background:#F2EDE4;color:#c2410c}.rv-topbar__actions .MuiButton-root.Mui-disabled{color:#b8ac9a}.rv-iconbtn{appearance:none;background:transparent;border:none;color:#4a4239;width:34px;height:34px;border-radius:6px;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:background .12s cubic-bezier(.2,.7,.2,1),color .12s cubic-bezier(.2,.7,.2,1)}.rv-iconbtn:hover{background:#F2EDE4;color:#c2410c}.rv-iconbtn:disabled{color:#b8ac9a;cursor:not-allowed;background:transparent}.rv-progress{height:2px;background:#E8E0D2;overflow:hidden}.rv-progress__fill{height:100%;background:#C2410C;transition:width .32s cubic-bezier(.2,.7,.2,1)}.rv-stage{flex:1;width:100%;max-width:720px;margin:0 auto;padding:48px 24px 64px;display:flex;flex-direction:column;align-items:stretch}.rv-counter{display:flex;align-items:center;gap:12px;margin-bottom:32px;color:#8b7f6f;font-size:.82rem;font-variant-numeric:tabular-nums;letter-spacing:.03em}.rv-counter__pos{color:#4a4239;font-weight:500}.rv-counter__sep{color:#b8ac9a}.rv-badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:999px;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em}.rv-badge--new{background:#E6EEFE;color:#2563eb}.rv-card{background:#FFFFFF;border:1px solid #E8E0D2;border-radius:20px;padding:48px 32px 24px;box-shadow:0 4px 12px #1f1b160f,0 1px 2px #1f1b160a;min-height:320px;display:flex;flex-direction:column}.rv-face{display:flex;flex-direction:column;align-items:stretch;flex:1;gap:24px}.rv-face__top{text-align:center;display:flex;flex-direction:column;align-items:center;gap:16px;padding:24px 0}.rv-face__top.is-front{padding:48px 0}.rv-face__front{font-family:Fraunces,Iowan Old Style,Apple Garamond,Georgia,Times New Roman,serif;font-size:clamp(2rem,6vw,3rem);font-weight:500;color:#1f1b16;line-height:1.15;letter-spacing:-.01em;word-break:break-word}.rv-face__image{max-width:100%;max-height:240px;border-radius:10px;object-fit:contain}.rv-face__top:not(.is-front) .rv-face__front{font-size:clamp(1.25rem,3vw,1.5rem);color:#4a4239;font-weight:500;font-style:italic}.rv-face__top:not(.is-front) .rv-face__image{max-height:160px}.rv-face__divider{height:1px;background:#E8E0D2;margin:0 auto;width:32px}.rv-face__back{text-align:center;font-family:Fraunces,Iowan Old Style,Apple Garamond,Georgia,Times New Roman,serif;font-size:clamp(1.75rem,5vw,2.5rem);color:#1f1b16;line-height:1.25;letter-spacing:-.005em;padding:24px 0;word-break:break-word;font-weight:500}.rv-reveal{appearance:none;margin-top:auto;width:100%;padding:16px 24px;background:#F2EDE4;color:#4a4239;border:1px dashed #D4C9B5;border-radius:10px;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:12px;font-size:.95rem;font-weight:500;transition:all .2s cubic-bezier(.2,.7,.2,1)}.rv-reveal:hover{background:#FEEDE3;border-color:#c2410c;color:#7c2a09}.rv-kbd{display:inline-flex;align-items:center;justify-content:center;padding:2px 8px;background:#FFFFFF;border:1px solid #E8E0D2;border-bottom-width:2px;border-radius:6px;font-family:ui-monospace,SF Mono,Menlo,Consolas,monospace;font-size:.72rem;color:#8b7f6f;line-height:1;min-width:22px;height:22px}.rv-kbd--inline{margin-left:8px}.rv-grades{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:auto;padding-top:8px}.rv-grade{appearance:none;border:1px solid #D4C9B5;background:#FFFFFF;padding:12px 16px;border-radius:10px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:8px;font-size:.95rem;font-weight:500;color:#1f1b16;transition:background .12s cubic-bezier(.2,.7,.2,1),border-color .12s cubic-bezier(.2,.7,.2,1),color .12s cubic-bezier(.2,.7,.2,1),transform .12s cubic-bezier(.2,.7,.2,1);min-height:52px}.rv-grade:hover{transform:translateY(-1px)}.rv-grade:active{transform:translateY(0)}.rv-grade--wrong:hover{background:#fceae9;border-color:#b42318;color:#b42318}.rv-grade--wrong:hover .rv-kbd{background:rgba(180,35,24,.08);border-color:#b423184d;color:#b42318}.rv-grade--hard:hover{background:#f9e8d8;border-color:#b5651d;color:#b5651d}.rv-grade--hard:hover .rv-kbd{background:rgba(181,101,29,.08);border-color:#b5651d4d;color:#b5651d}.rv-grade--good:hover{background:#E3F1E9;border-color:#2d7a4f;color:#2d7a4f}.rv-grade--good:hover .rv-kbd{background:rgba(45,122,79,.08);border-color:#2d7a4f4d;color:#2d7a4f}.rv-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:96px 24px;gap:12px}.rv-empty__face{font-family:ui-monospace,SF Mono,Menlo,Consolas,monospace;font-size:2.5rem;color:#c2410c;margin-bottom:12px}.rv-empty__title{font-family:Fraunces,Iowan Old Style,Apple Garamond,Georgia,Times New Roman,serif;font-size:1.75rem;font-weight:500;color:#1f1b16;margin:0}.rv-empty__sub{color:#8b7f6f;margin:0;max-width:360px}.rv-empty__cta{margin-top:16px}.rv-btn{display:inline-flex;align-items:center;justify-content:center;padding:12px 24px;border-radius:10px;font-size:.95rem;font-weight:500;transition:background .12s cubic-bezier(.2,.7,.2,1);text-decoration:none}.rv-btn--primary{background:#C2410C;color:#fff}.rv-btn--primary:hover{background:#9A3309;color:#fff}.rv-loading{flex:1;max-width:720px;margin:0 auto;padding:48px 24px;width:100%}.rv-loading__pulse{height:320px;background:#F2EDE4;border-radius:20px;border:1px solid #E8E0D2;animation:rvPulse 1.6s ease-in-out infinite}@keyframes rvPulse{0%,to{opacity:1}50%{opacity:.7}}@media (max-width: 640px){.rv-stage{padding:24px 16px 48px}.rv-card{padding:24px 16px 16px;min-height:260px}.rv-grades{gap:8px}.rv-grade{padding:12px 8px;font-size:.88rem;min-height:56px}.rv-kbd--inline{display:none}.rv-topbar__deck{font-size:.9rem}}.center-horizontal,.action-container{display:none}.canvas-card canvas{background-color:#fff}.public-deck-container{display:flex;flex-direction:row}@media screen and (max-width: 600px){.public-deck-container{flex-direction:column;align-items:center}}.public-deck-container .public-deck-sidebar{height:100%;width:20%;max-width:280px;font-size:36px;padding:32px}@media screen and (max-width: 600px){.public-deck-container .public-deck-sidebar{width:unset;max-width:unset}}.public-deck-container .deck-container{margin-top:32px;display:flex;gap:32px 64px;flex-direction:row;flex-wrap:wrap;align-content:flex-start}.public-deck-container .deck-container .public-deck{width:256px;height:256px;border-radius:8px;background-color:#111213;position:relative}.public-deck-container .deck-container .public-deck .name{font-size:24px;font-weight:600;padding-top:32px;text-align:center}.public-deck-container .deck-container .public-deck .actions{position:absolute;bottom:32px;left:32px;right:32px;display:flex;justify-content:space-between;line-height:36.5px}.under-construction{display:flex;align-items:center;justify-content:center;flex-direction:column;min-height:calc(100vh - 70px)}.under-construction .alerts{margin:0;bottom:15%;pointer-events:none}.under-construction .alerts .alert-fill{position:relative;z-index:-1;left:14px;background-color:#fff;width:3px;height:14px}
