.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__btn--status{display:inline-flex;align-items:center;gap:6px}.library-filter__btn--status:before{content:"";width:6px;height:6px;border-radius:50%;background:currentColor;display:inline-block}.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 max(12px,env(safe-area-inset-bottom));border-top:1px solid var(--color-neutral-100);flex-shrink:0;order:99}@media (max-width: 767px){.library-surprise{padding-bottom:max(34px,env(safe-area-inset-bottom))}}.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:not(:disabled){background:color-mix(in srgb,var(--color-primary) 6%,transparent);border-color:var(--color-primary)}.library-surprise__btn:disabled{opacity:.5;cursor:default}.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)}.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}.puzzle-canvas--hover{z-index:3;pointer-events:none}.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;padding-bottom:max(12px,env(safe-area-inset-bottom));flex-shrink:0;background:var(--surface-puzzle)}@media (max-width: 767px){.game-view__controls{padding-bottom:max(34px,env(safe-area-inset-bottom))}}.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:var(--surface-puzzle)}}.game-view__solved-badge{font-family:var(--font-heading);font-size:16px;font-weight:600;color:var(--color-success);padding:10px 16px}.game-view__ctrl-btn--checkpoint{color:var(--color-neutral-400)}.game-view__testmode-pill{display:inline-flex;align-items:center;gap:4px;padding:4px;border:1px solid #E8B88A;border-radius:999px;background:#e8b88a14}.game-view__testmode-btn{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;min-height:36px;border:none;background:transparent;font-family:var(--font-heading);font-size:14px;font-weight:600;color:var(--color-neutral-600, #57534E);border-radius:999px;cursor:pointer;transition:background .15s}.game-view__testmode-btn:hover{background:#e8b88a2e}.game-view__testmode-btn:active{background:#e8b88a47}.game-view__testmode-btn--revert{color:#8a7358}.game-view__testmode-btn--keep{color:#6baf7b}.stats-view{flex:1;overflow-y:auto;background:var(--surface-page);padding:16px;padding-bottom:calc(32px + env(safe-area-inset-bottom));display:flex;flex-direction:column;gap:16px;-webkit-overflow-scrolling:touch}.stats-view__header{display:flex;align-items:center;gap:12px}.stats-view__back{display:inline-flex;align-items:center;gap:4px;background:none;border:none;color:var(--color-neutral-400);font-family:var(--font-body);font-size:15px;padding:6px 8px;margin-left:-8px;cursor:pointer;border-radius:var(--radius-md);transition:background .15s}.stats-view__back:hover{background:var(--color-neutral-100)}.stats-view__title{font-family:var(--font-heading);font-size:22px;font-weight:600;color:var(--color-neutral-500);margin:0}.stats-view__tabs{display:flex;gap:4px;background:var(--color-neutral-100);border-radius:var(--radius-md);padding:4px}.stats-view__tab{flex:1;background:transparent;border:none;font-family:var(--font-heading);font-size:14px;font-weight:600;color:var(--color-neutral-400);padding:8px 14px;cursor:pointer;border-radius:var(--radius-sm);transition:background .15s,color .15s}.stats-view__tab--active{background:var(--surface-card);color:var(--color-neutral-500);box-shadow:var(--elevation-1)}.stats-view__content{display:flex;flex-direction:column;gap:20px}.stats-view__hint{font-family:var(--font-body);color:var(--color-neutral-400);font-size:14px;margin:0}.stats-view__sub-hint{font-family:var(--font-body);color:var(--color-neutral-400);font-size:13px;margin:4px 0 0;line-height:1.5}.stats-view__empty{background:var(--surface-card);border:1px dashed var(--color-neutral-200);border-radius:var(--radius-lg);padding:20px}.stats-view__empty code{font-family:var(--font-mono);font-size:12px;background:var(--color-neutral-100);padding:1px 6px;border-radius:var(--radius-sm)}.stats-tiles{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:12px}.stats-tile{background:var(--surface-card);border-radius:var(--radius-lg);padding:14px 16px;box-shadow:var(--elevation-1)}.stats-tile__value{font-family:var(--font-heading);font-size:22px;font-weight:600;color:var(--color-neutral-500);line-height:1.2}.stats-tile__label{font-family:var(--font-body);font-size:12px;color:var(--color-neutral-400);margin-top:2px}.stats-section{background:var(--surface-card);border-radius:var(--radius-lg);padding:16px;box-shadow:var(--elevation-1)}.stats-section__title{font-family:var(--font-heading);font-size:14px;font-weight:600;color:var(--color-neutral-400);text-transform:uppercase;letter-spacing:.06em;margin:0 0 12px}.stats-grid-2{display:grid;grid-template-columns:1fr;gap:16px}@media (min-width: 640px){.stats-grid-2{grid-template-columns:1fr 1fr}}.stats-chart{width:100%;height:auto;display:block}.stats-chart__empty{font-family:var(--font-body);color:var(--color-neutral-400);font-size:14px;padding:24px 0;text-align:center}.stats-chart__value{font-family:var(--font-mono);font-size:11px;fill:var(--color-neutral-500)}.stats-chart__label{font-family:var(--font-body);font-size:11px;fill:var(--color-neutral-400)}.stats-chart__grid{stroke:var(--color-neutral-200);stroke-width:1;stroke-dasharray:2 3}.stats-scatter{display:flex;flex-direction:column;gap:10px}.stats-scatter__legend{display:flex;flex-wrap:wrap;gap:12px;font-family:var(--font-body);font-size:12px;color:var(--color-neutral-400)}.stats-scatter__legend-item{display:inline-flex;align-items:center;gap:6px}.stats-scatter__legend-swatch{display:inline-block;width:10px;height:10px;border-radius:50%}.stats-activity{list-style:none;margin:0;padding:0;font-family:var(--font-mono);font-size:12px;color:var(--color-neutral-500);max-height:320px;overflow-y:auto}.stats-activity__row{display:grid;grid-template-columns:70px 120px 1fr;gap:8px;padding:4px 0;border-bottom:1px solid var(--color-neutral-100)}.stats-activity__row:last-child{border-bottom:none}.stats-activity__time{color:var(--color-neutral-400)}.stats-activity__type{color:var(--color-primary-dark)}.stats-activity__detail{color:var(--color-neutral-500);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.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}.nav-bar__build{position:absolute;bottom:3px;right:8px;font-family:var(--font-mono, ui-monospace, monospace);font-size:9px;line-height:1;color:var(--color-neutral-300);opacity:.55;pointer-events:none;-webkit-user-select:none;user-select:none;letter-spacing:.04em}.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-panel__toggle{display:flex;align-items:center;gap:10px;font-family:var(--font-body);font-size:16px;color:var(--color-neutral-500);cursor:pointer}.settings-panel__toggle input{width:18px;height:18px;accent-color:var(--color-neutral-500)}.settings-panel__hint{font-family:var(--font-body);font-size:13px;color:var(--color-neutral-400);margin:0}.settings-panel__link-btn{font-family:var(--font-body);font-size:15px;color:var(--color-neutral-500);background:none;border:none;padding:6px 0;text-align:left;cursor:pointer;transition:opacity .15s}.settings-panel__link-btn:hover:not(:disabled){opacity:.75}.settings-panel__link-btn:disabled{color:var(--color-neutral-300);cursor:not-allowed}.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:100dvh;height:100vh;overflow:hidden}#root{height:100dvh;height:100vh;display:flex;flex-direction:column;overflow:hidden;box-sizing:border-box}: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}
