.completion-counter{font-size:.95rem;color:var(--color-text-secondary, #aaa);padding:8px 16px 0;letter-spacing:.02em;flex-shrink:0}.library-filter{display:flex;flex-wrap:wrap;gap:8px;padding:12px 16px 0;align-items:center;flex-shrink:0}.library-filter__btn{font-family:var(--font-heading);font-size:11px;font-weight:500;padding:4px 10px;border-radius:var(--radius-full);border:1.5px solid var(--color-neutral-200);background:transparent;color:var(--color-neutral-400);cursor:pointer;text-transform:uppercase;letter-spacing:.04em;transition:border-color .15s,background .15s,color .15s;-webkit-tap-highlight-color:transparent}.library-filter__btn:hover{border-color:var(--color-primary-light);color:var(--color-primary)}.library-filter__btn--active{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.library-filter__btn--active:hover{background:var(--color-primary-dark);border-color:var(--color-primary-dark)}.library-filter__clear{font-family:var(--font-body);font-size:12px;color:var(--color-neutral-400);background:none;border:none;cursor:pointer;padding:4px 8px;border-radius:var(--radius-md);transition:color .15s}.library-filter__clear:hover{color:var(--color-neutral-500)}.library-filter__size-select{font-family:var(--font-heading);font-size:11px;font-weight:500;padding:4px 24px 4px 10px;border-radius:var(--radius-full);border:1.5px solid var(--color-neutral-200);background:transparent;color:var(--color-neutral-400);cursor:pointer;text-transform:uppercase;letter-spacing:.04em;-moz-appearance:none;appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg width='10' height='6' viewBox='0 0 10 6' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%23A8A29E' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 8px center;transition:border-color .15s,color .15s;margin-left:auto}.library-filter__size-select:focus{outline:none;border-color:var(--color-primary-light)}.library-filter__size-select--active{border-color:var(--color-primary);color:var(--color-primary);background-image:url("data:image/svg+xml,%3Csvg width='10' height='6' viewBox='0 0 10 6' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%239B8EC4' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E")}.library-view{flex:1;display:flex;flex-direction:column;overflow:hidden;background:var(--surface-page)}.library-view__content{flex:1;overflow-y:auto;padding:16px}.library-view__grid{display:grid;grid-template-columns:repeat(2,minmax(148px,1fr));gap:12px}@media (min-width: 768px){.library-view__grid{grid-template-columns:repeat(3,minmax(200px,1fr))}}@media (min-width: 1024px){.library-view__grid{grid-template-columns:repeat(4,minmax(200px,1fr));max-width:960px;margin-inline:auto}}.library-view__empty{display:flex;align-items:center;justify-content:center;height:200px;color:var(--color-neutral-400);font-family:var(--font-body)}.library-surprise{padding:10px 16px calc(10px + env(safe-area-inset-bottom));border-top:1px solid var(--color-neutral-100);flex-shrink:0;order:99}.library-surprise__btn{width:100%;font-family:var(--font-heading);font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;padding:10px 0;border-radius:var(--radius-md);border:1.5px dashed var(--color-primary-light);background:transparent;color:var(--color-primary);cursor:pointer;transition:background .15s,border-color .15s;-webkit-tap-highlight-color:transparent}.library-surprise__btn:hover{background:color-mix(in srgb,var(--color-primary) 6%,transparent);border-color:var(--color-primary)}.library-surprise__generating{width:100%;text-align:center;font-family:var(--font-body);font-size:13px;color:var(--color-neutral-400);padding:10px 0}.library-surprise__error{font-family:var(--font-body);font-size:12px;color:#c0392b;margin:6px 0 0;text-align:center}.puzzle-card{display:flex;flex-direction:column;background:var(--surface-card);border-radius:var(--radius-md);box-shadow:var(--elevation-1);padding:16px;border:none;cursor:pointer;text-align:left;transition:box-shadow .2s ease-out,transform .2s ease-out;-webkit-tap-highlight-color:transparent;width:100%}.puzzle-card:hover{box-shadow:var(--elevation-2);transform:translateY(-2px)}.puzzle-card:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.puzzle-card:active{box-shadow:var(--elevation-1);transform:translateY(0) scale(.98)}.puzzle-card--completed{border-left:3px solid var(--color-accent)}.puzzle-card__thumbnail{position:relative;aspect-ratio:1;background:var(--surface-puzzle);border-radius:6px;display:flex;align-items:center;justify-content:center;margin-bottom:12px;overflow:hidden;color:var(--color-neutral-300)}.puzzle-card--completed .puzzle-card__thumbnail{color:var(--color-primary-light)}.puzzle-card--in-progress .puzzle-card__thumbnail{color:var(--color-neutral-200)}.puzzle-card__grid-svg{max-width:70%;max-height:70%}.puzzle-card__in-progress-dot{position:absolute;top:8px;right:8px;width:8px;height:8px;background:var(--color-primary);border-radius:50%}.puzzle-card__body{display:flex;flex-direction:column;gap:6px}.puzzle-card__label{font-family:var(--font-heading);font-size:14px;font-weight:600;color:var(--color-neutral-500)}.puzzle-card__time{font-family:var(--font-mono);font-size:12px;color:var(--color-neutral-400)}.difficulty-badge{display:inline-block;font-family:var(--font-heading);font-size:11px;font-weight:500;padding:4px 10px;border-radius:var(--radius-full);text-transform:uppercase;letter-spacing:.04em;line-height:1.3;white-space:nowrap}.grid-size-selector{display:flex;overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;gap:var(--space-2, 8px);scrollbar-width:none;-ms-overflow-style:none;padding:2px}.grid-size-selector::-webkit-scrollbar{display:none}.grid-size-chip{scroll-snap-align:start;flex-shrink:0;min-width:56px;height:32px;padding:6px 14px;border-radius:var(--radius-full, 9999px);font-family:var(--font-heading, "Outfit", sans-serif);font-size:13px;font-weight:600;white-space:nowrap;background:transparent;border:1.5px solid var(--color-neutral-200, #D9D5CC);color:var(--color-neutral-400, #78716C);cursor:pointer;transition:background-color .15s ease-out,color .15s ease-out,border-color .15s ease-out;display:inline-flex;align-items:center;justify-content:center;line-height:1}.grid-size-chip:hover:not(.grid-size-chip--selected){background:var(--color-neutral-100, #EDEAE3);color:var(--color-neutral-500, #44403C)}.grid-size-chip--selected{background:var(--color-primary, #9B8EC4);border-color:transparent;color:#fff;cursor:default}.grid-size-chip:focus-visible{outline:2px solid var(--color-primary, #9B8EC4);outline-offset:2px}.ios-banner{position:fixed;bottom:0;left:0;right:0;display:flex;align-items:center;gap:12px;padding:16px 16px calc(16px + env(safe-area-inset-bottom));background:var(--surface-card);box-shadow:var(--elevation-2);border-radius:12px 12px 0 0;z-index:200}.ios-banner__icon{flex-shrink:0;border-radius:10px;overflow:hidden}.ios-banner__icon img{display:block;border-radius:10px}.ios-banner__text{flex:1;display:flex;flex-direction:column;gap:2px;min-width:0}.ios-banner__title{font-family:var(--font-heading);font-size:16px;font-weight:600;color:var(--color-neutral-500);line-height:1.3}.ios-banner__sub{font-family:var(--font-body);font-size:14px;color:var(--color-neutral-400);line-height:1.4}.ios-banner__close{align-self:flex-start;margin-top:-4px}.daily-section{padding:12px 16px;border-bottom:1px solid var(--color-neutral-100);flex-shrink:0}.daily-section__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}.daily-section__label{font-family:var(--font-heading);font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--color-primary)}.daily-section__date{font-family:var(--font-body);font-size:14px;font-weight:500;color:var(--color-neutral-500);margin-top:2px}.daily-section__streak{display:flex;align-items:center;gap:4px;color:#e07b39;font-family:var(--font-heading);font-size:14px;font-weight:600}.daily-section__card{width:100%;display:flex;align-items:center;justify-content:space-between;padding:12px 14px;border-radius:var(--radius-lg);border:1.5px solid var(--color-neutral-200);background:var(--surface-card);cursor:pointer;-webkit-tap-highlight-color:transparent;transition:border-color .15s,background .15s}.daily-section__card:hover{border-color:var(--color-primary-light);background:var(--color-neutral-50)}.daily-section__card--completed{border-color:var(--color-primary-light);background:color-mix(in srgb,var(--color-primary) 6%,var(--surface-card))}.daily-section__card-left{display:flex;align-items:center;gap:8px}.daily-section__size{font-family:var(--font-heading);font-size:13px;font-weight:600;color:var(--color-neutral-500)}.daily-section__time{font-family:var(--font-body);font-size:12px;color:var(--color-neutral-400)}.daily-section__cta{font-family:var(--font-heading);font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--color-primary)}.daily-section__card--completed .daily-section__cta{color:var(--color-neutral-400)}.daily-section__dots{display:flex;gap:6px;padding:6px 16px 8px;align-items:center}.daily-section__dot{width:8px;height:8px;border-radius:50%;flex-shrink:0;display:inline-block}.daily-section__dot--not-started{border:1.5px solid var(--color-neutral-300);background:transparent}.daily-section__dot--in-progress{background:linear-gradient(90deg,var(--color-primary) 50%,transparent 50%);border:1.5px solid var(--color-primary-light)}.daily-section__dot--completed{background:var(--color-primary);border:1.5px solid var(--color-primary)}.surprise-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--surface-overlay);backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);display:flex;align-items:flex-end;justify-content:center;z-index:200}.surprise-sheet{background:var(--surface-card);border-radius:var(--radius-lg) var(--radius-lg) 0 0;padding:12px 0 calc(20px + env(safe-area-inset-bottom));width:100%;max-width:480px;animation:sheetEnter .28s ease-out}@keyframes sheetEnter{0%{transform:translateY(100%)}to{transform:translateY(0)}}.surprise-sheet__handle{width:36px;height:4px;background:var(--color-neutral-200);border-radius:2px;margin:0 auto 16px}.surprise-sheet__title{font-family:var(--font-heading);font-size:16px;font-weight:700;color:var(--color-neutral-500);margin:0 0 8px;padding:0 20px}.surprise-sheet__list{list-style:none;margin:0;padding:0}.surprise-sheet__item{width:100%;display:flex;align-items:center;justify-content:space-between;padding:14px 20px;background:none;border:none;cursor:pointer;-webkit-tap-highlight-color:transparent;transition:background .12s;text-align:left}.surprise-sheet__item:hover,.surprise-sheet__item:active{background:var(--color-neutral-50)}.surprise-sheet__item-label{font-family:var(--font-heading);font-size:15px;font-weight:600;color:var(--color-neutral-500)}.surprise-sheet__item-hint{font-family:var(--font-body);font-size:13px;color:var(--color-neutral-400)}.surprise-sheet__item--random .surprise-sheet__item-label{color:var(--color-primary)}.puzzle-canvas-container{position:relative;flex-shrink:0;width:100%;height:100%}.puzzle-canvas{position:absolute;top:0;left:0;display:block}.puzzle-canvas--static{z-index:1;pointer-events:none}.puzzle-canvas--dynamic{z-index:2;touch-action:none;cursor:crosshair}.zoom-layer{width:100%;height:100%;flex:1;align-self:stretch;overflow:hidden;position:relative;touch-action:none;display:flex;align-items:center;justify-content:center}.zoom-layer__transform{transform-origin:center center;transition:transform .2s ease-out;will-change:transform;display:flex;align-items:center;justify-content:center;width:100%;height:100%}.zoom-layer__transform--active{transition:none}.minimap{position:absolute;bottom:12px;right:12px;background:#f7f5f0e0;border:1px solid var(--color-neutral-200);border-radius:6px;overflow:hidden;pointer-events:none;box-shadow:0 1px 4px #0000001a;z-index:10;opacity:1;transition:opacity .6s ease}.minimap--hidden{opacity:0}.minimap__viewport{position:absolute;background:#9b8ec440;border:1.5px solid var(--color-primary);border-radius:2px;box-sizing:border-box}.completion-overlay{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:var(--surface-overlay, rgba(68, 64, 60, .5));-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:100}.completion-modal__card{background:var(--surface-card, #fff);max-width:340px;width:90%;border-radius:12px;box-shadow:0 8px 40px #0003,0 2px 8px #0000001a;display:flex;flex-direction:column;align-items:center;padding:0 24px 24px;overflow:hidden;animation:modalEnter .25s ease-out both}@keyframes modalEnter{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.completion-modal__accent{width:calc(100% + 48px);height:4px;background:linear-gradient(90deg,#b8942a,#f0d060,#b8942a);margin-bottom:24px;flex-shrink:0}.completion-modal__title{font-family:var(--font-heading, "Outfit", sans-serif);font-size:32px;font-weight:700;color:var(--text-primary, #1c1917);margin:0 0 8px;text-align:center}.completion-modal__time{font-family:var(--font-mono, "DM Mono", monospace);font-size:28px;font-weight:500;color:var(--text-secondary, #78716c);margin-bottom:16px}.completion-modal__stats{display:flex;align-items:center;gap:12px;margin-bottom:24px}.completion-modal__btn{width:100%;padding:12px 16px;border-radius:var(--radius-md, 8px);font-family:var(--font-heading, "Outfit", sans-serif);font-size:16px;font-weight:600;cursor:pointer;transition:opacity .15s,background .15s,border-color .15s}.completion-modal__btn--primary{background:var(--color-primary, #9B8EC4);color:#fff;border:none;margin-bottom:8px}.completion-modal__btn--primary:hover{opacity:.88}.completion-modal__btn--primary:active{opacity:.75}.completion-modal__btn--ghost{background:transparent;color:var(--text-secondary, #78716c);border:1.5px solid var(--color-neutral-300, #d6d3d1)}.completion-modal__btn--ghost:hover{border-color:var(--color-neutral-500, #78716c);color:var(--text-primary, #1c1917)}.game-view{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;background:var(--surface-puzzle);overflow:hidden;width:100%;max-height:100%}.game-view__board{display:flex;align-items:center;justify-content:center;width:100%;flex:1;overflow:hidden}.game-view__placeholder,.game-view__loading{font-family:var(--font-body);color:var(--color-neutral-400);font-size:14px}.game-view__controls{display:flex;align-items:center;justify-content:center;gap:8px;padding:8px 16px;flex-shrink:0}.game-view__ctrl-btn:disabled{opacity:.35;pointer-events:none}.game-view__ctrl-btn--zoom{display:none}@media (min-width: 768px){.game-view__ctrl-btn--zoom{display:inline-flex}}.game-view__check-btn{font-family:var(--font-heading);font-size:16px;font-weight:600;color:#fff;background:var(--color-primary);border:none;border-radius:var(--radius-md);padding:10px 20px;cursor:pointer;transition:opacity .15s,background .15s;min-height:44px}.game-view__check-btn:hover{opacity:.88}.game-view__check-btn:active{background:var(--color-primary-dark)}.game-view__check-btn:disabled{opacity:.45;pointer-events:none}.game-view__controls--error{animation:errorFlash 1.5s ease-out}@keyframes errorFlash{0%{background:#d4645c1f}to{background:transparent}}.game-view__solved-badge{font-family:var(--font-heading);font-size:16px;font-weight:600;color:var(--color-success);padding:10px 16px}.nav-bar{display:flex;align-items:center;justify-content:space-between;height:calc(56px + env(safe-area-inset-top));padding-top:env(safe-area-inset-top);padding-inline:8px;background:var(--surface-elevated);box-shadow:var(--elevation-1);position:relative;z-index:10;flex-shrink:0}.nav-bar__title{font-family:var(--font-heading);font-size:16px;font-weight:600;color:var(--color-neutral-500);position:absolute;left:50%;transform:translate(-50%);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:calc(100% - 120px);display:flex;flex-direction:column;align-items:center;gap:1px}.nav-bar__subtitle{font-size:10px;font-weight:400;color:var(--color-neutral-300);letter-spacing:.02em}.nav-bar__left,.nav-bar__right{display:flex;align-items:center;min-width:44px}.nav-bar__spacer{display:block;width:44px}.icon-btn{display:inline-flex;align-items:center;justify-content:center;width:44px;height:44px;background:transparent;border:none;border-radius:50%;color:var(--color-neutral-400);cursor:pointer;transition:background .15s ease,color .15s ease,transform .1s ease;flex-shrink:0;-webkit-tap-highlight-color:transparent}.icon-btn:hover{background:var(--color-neutral-100);color:var(--color-neutral-500)}.icon-btn:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.icon-btn:active{background:var(--color-neutral-200);transform:scale(.92)}.icon-btn:disabled{opacity:.35;pointer-events:none}.settings-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--surface-overlay);z-index:100;animation:fadeIn .2s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.settings-panel{position:fixed;top:0;right:0;bottom:0;width:min(360px,100vw);background:var(--surface-card);box-shadow:var(--elevation-3);z-index:101;display:flex;flex-direction:column;transform:translate(100%);transition:transform .25s ease-out;padding-top:env(safe-area-inset-top);padding-bottom:calc(16px + env(safe-area-inset-bottom))}.settings-panel--open{transform:translate(0);animation:slideInRight .25s ease-out}@keyframes slideInRight{0%{transform:translate(100%)}to{transform:translate(0)}}.settings-panel__header{display:flex;align-items:center;justify-content:space-between;padding:16px 8px 16px 20px}.settings-panel__title{font-family:var(--font-heading);font-size:20px;font-weight:600;color:var(--color-neutral-500)}.settings-panel__content{flex:1;overflow-y:auto}.settings-panel__divider{height:1px;background:var(--color-neutral-200);margin:0}.settings-panel__section{padding:20px;display:flex;flex-direction:column;gap:12px}.settings-panel__section-title{font-family:var(--font-heading);font-size:12px;font-weight:600;color:var(--color-neutral-400);text-transform:uppercase;letter-spacing:.06em}.settings-panel__danger-btn{font-family:var(--font-body);font-size:16px;color:var(--color-error);background:none;border:none;cursor:pointer;padding:8px 0;text-align:left;transition:opacity .15s}.settings-panel__danger-btn:hover{opacity:.75}.settings-confirm{position:absolute;top:0;right:0;bottom:0;left:0;background:var(--surface-overlay);display:flex;align-items:center;justify-content:center;padding:24px;z-index:102}.settings-confirm__content{background:var(--surface-card);border-radius:var(--radius-lg);padding:24px;box-shadow:var(--elevation-4);display:flex;flex-direction:column;gap:20px}.settings-confirm__text{font-family:var(--font-body);font-size:16px;color:var(--color-neutral-500);line-height:1.5}.settings-confirm__actions{display:flex;gap:12px;justify-content:flex-end}.settings-confirm__cancel{font-family:var(--font-heading);font-size:16px;font-weight:600;color:var(--color-neutral-400);background:transparent;border:1.5px solid var(--color-neutral-200);border-radius:var(--radius-md);padding:10px 20px;cursor:pointer;transition:border-color .15s,color .15s}.settings-confirm__cancel:hover{border-color:var(--color-neutral-300);color:var(--color-neutral-500)}.settings-confirm__confirm{font-family:var(--font-heading);font-size:16px;font-weight:600;color:#fff;background:var(--color-error);border:none;border-radius:var(--radius-md);padding:10px 20px;cursor:pointer;transition:opacity .15s}.settings-confirm__confirm:hover{opacity:.85}:root{--color-primary: #9B8EC4;--color-primary-light: #B8AED6;--color-primary-dark: #7A6DA8;--color-accent: #D4A853;--color-accent-light: #E2C47A;--color-accent-dark: #B8903E;--color-neutral-50: #F7F5F0;--color-neutral-100: #EDEAE3;--color-neutral-200: #D9D5CC;--color-neutral-300: #A8A29E;--color-neutral-400: #78716C;--color-neutral-500: #44403C;--color-success: #6BAF7B;--color-success-light: #E8F5EB;--color-error: #D4645C;--color-error-light: #FAEAE9;--color-warning: #D4A253;--color-warning-light: #FDF5E6;--color-info: #6B9DC4;--color-info-light: #EAF1F8;--surface-page: #F7F5F0;--surface-card: #FFFFFF;--surface-elevated: #FFFFFF;--surface-overlay: rgba(68, 64, 60, .5);--surface-puzzle: #FDFCFA;--edge-empty: transparent;--edge-active: #9B8EC4;--edge-active-glow: rgba(155, 142, 196, .35);--edge-marked-x: #A8A29E;--edge-warning: #D4A253;--font-heading: "Outfit", system-ui, -apple-system, sans-serif;--font-body: "DM Sans", system-ui, -apple-system, sans-serif;--font-mono: "DM Mono", ui-monospace, Menlo, Consolas, monospace;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--radius-full: 9999px;--elevation-1: 0 1px 3px rgba(0,0,0,.08), 0 1px 2px rgba(0,0,0,.04);--elevation-2: 0 4px 6px rgba(0,0,0,.07), 0 2px 4px rgba(0,0,0,.05);--elevation-3: 0 10px 15px rgba(0,0,0,.07), 0 4px 6px rgba(0,0,0,.04);--elevation-4: 0 20px 25px rgba(0,0,0,.08), 0 10px 10px rgba(0,0,0,.03)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{background:var(--surface-page);color:var(--color-neutral-500);font-family:var(--font-body);height:100svh;height:100vh;overflow:hidden}#root{height:100svh;height:100vh;display:flex;flex-direction:column;overflow:hidden;box-sizing:border-box;padding-bottom:env(safe-area-inset-bottom)}:root{--font-heading: "Outfit", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;--font-body: "DM Sans", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;--font-mono: "DM Mono", ui-monospace, "Cascadia Code", "Source Code Pro", Menlo, Consolas, monospace}
