@keyframes shimmer{0%{background-position:-400px 0}to{background-position:400px 0}}@keyframes fade-in{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}@keyframes slide-in-left{0%{opacity:0;transform:translate(-100%)}to{opacity:1;transform:translate(0)}}@keyframes slide-in-right{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}.header{width:100%;height:var(--header-height);z-index:var(--z-header);background:var(--color-surface);border-bottom:1px solid var(--color-border);padding:0 var(--space-4);box-sizing:border-box;justify-content:space-between;align-items:center;display:flex;position:fixed;top:0;left:0}.header .header__title{font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);color:var(--color-primary);line-height:var(--line-height-tight);margin:0}.header .header__logo-link{color:inherit;align-items:center;text-decoration:none;display:flex}.header .header__logo{width:auto;height:auto;max-height:36px;display:block}.header .header__title-text{font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);color:var(--color-primary)}.header .header__logo+.header__title-text{clip:rect(0, 0, 0, 0);width:1px;height:1px;position:absolute;overflow:hidden}.header .header__title.logo-failed .header__logo{display:none}.header .header__title.logo-failed .header__title-text{clip:auto;width:auto;height:auto;position:static;overflow:visible}.header .header__btn{color:var(--color-text);font-size:var(--font-size-base);font-weight:var(--font-weight-medium);padding:var(--space-2) var(--space-3);cursor:pointer;border-radius:var(--radius-sm);transition:background var(--duration-fast) var(--easing-default), color var(--duration-fast) var(--easing-default);background:0 0;border:none}.header .header__btn:hover{background:var(--color-primary-50);color:var(--color-primary-700)}.header .header__btn:active{background:var(--color-primary-100);color:var(--color-primary-700)}.main{padding-top:var(--header-height);background:var(--color-surface,#fff);min-height:100vh}.state[hidden]{display:none!important}.state{min-height:calc(100vh - var(--header-height));padding:var(--space-6);text-align:center;flex-direction:column;justify-content:center;align-items:center;display:flex}.state .state__message{font-size:var(--font-size-md);margin:var(--space-4);line-height:var(--line-height-base)}.state .state__btn{background:var(--color-primary);color:var(--color-text-inverse,#333);font-size:var(--font-size-base);font-weight:var(--font-weight-bold);padding:var(--space-3) var(--space-5);border-radius:var(--radius-full);cursor:pointer;transition:background var(--duration-fast) var(--easing-default), box-shadow var(--duration-fast) var(--easing-default);border:none;justify-content:center;align-items:center;display:inline-flex}.state .state__btn:hover{background:var(--gradient-brand,var(--color-primary-dark));box-shadow:var(--shadow-sm)}.state .state__btn:active{background:var(--color-primary-dark)}.state.state--loading .skeleton{width:100%;max-width:360px}.state.state--loading .skeleton__rect{aspect-ratio:3/4;border-radius:var(--radius-md);background:linear-gradient(90deg, var(--color-primary-50) 25%, var(--color-neutral-100) 50%, var(--color-primary-50) 75%);background-size:800px 100%;width:80%;margin:0 auto;animation:1.5s linear infinite shimmer}.state.state--error .state__message{color:var(--color-error)}.state.state--empty .state__message{color:var(--color-text-muted)}.viewer[hidden]{display:none!important}.viewer{flex-direction:column;align-items:center;width:100%;display:flex}.viewer .viewer__canvas-container{width:100%;height:calc(100vh - var(--header-height));justify-content:flex-start;align-items:flex-start;display:flex;position:relative;overflow:auto}.viewer .viewer__canvas-container.slide-left{animation:slide-in-left var(--duration-normal) var(--easing-default)}.viewer .viewer__canvas-container.slide-right{animation:slide-in-right var(--duration-normal) var(--easing-default)}.viewer .viewer__canvas-container canvas{flex-shrink:0;margin:auto;display:block}.viewer .viewer__zoom{bottom:var(--space-6);right:var(--space-4);gap:var(--space-2);z-index:var(--z-base);flex-direction:column;display:flex;position:fixed}.viewer .viewer__zoom .viewer__zoom-btn{border-radius:var(--radius-full);background:var(--color-surface);border:1px solid var(--color-border);width:44px;height:44px;box-shadow:var(--shadow-md);cursor:pointer;font-size:var(--font-size-lg);color:var(--color-primary-700);transition:background var(--duration-fast) var(--easing-default), box-shadow var(--duration-fast) var(--easing-default), border-color var(--duration-fast) var(--easing-default);justify-content:center;align-items:center;display:inline-flex}.viewer .viewer__zoom .viewer__zoom-btn:hover{background:var(--color-primary-50);border-color:var(--color-primary-400);box-shadow:var(--shadow-lg)}.viewer .viewer__zoom .viewer__zoom-btn:active{background:var(--color-primary-100);box-shadow:var(--shadow-sm)}.viewer .viewer__indicator{bottom:var(--space-5);background:var(--color-primary-700);color:#fff;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);padding:var(--space-1) var(--space-4);border-radius:var(--radius-full);z-index:var(--z-base);pointer-events:none;white-space:nowrap;box-shadow:var(--shadow-sm);position:fixed;left:50%;transform:translate(-50%)}.offline-badge{top:calc(var(--header-height) + var(--space-2));right:var(--space-3);background:var(--color-warning);color:var(--color-neutral-900);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);padding:var(--space-1) var(--space-3);border-radius:var(--radius-full);z-index:var(--z-header);box-shadow:var(--shadow-sm);animation:.3s fade-in;position:fixed}.viewer__cached-badge{bottom:calc(var(--space-5) + var(--space-6));background:var(--color-primary-700);color:#ffffffe6;font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);padding:var(--space-1) var(--space-3);border-radius:var(--radius-full);z-index:var(--z-base);pointer-events:none;white-space:nowrap;animation:.3s fade-in;position:fixed;left:50%;transform:translate(-50%)}.state--no-cache .state__icon{margin-bottom:var(--space-2);color:var(--color-text-muted);opacity:.6;font-size:3rem}.state--no-cache .state__message{color:var(--color-text-muted)}.state--no-cache .state__sub{font-size:var(--font-size-sm);color:var(--color-text-muted);opacity:.7;margin-top:var(--space-2);line-height:var(--line-height-base)}@media (width>=768px){.viewer{margin:0 auto}}.page-nav{background:var(--color-primary-700);color:#fff;cursor:pointer;z-index:9999;width:48px;height:48px;box-shadow:var(--shadow-md);border:none;border-radius:50%;justify-content:center;align-items:center;font-size:1.75rem;line-height:1;transition:background .15s;display:flex;position:fixed;top:50%;transform:translateY(-50%)}.page-nav:hover{background:var(--color-primary-800)}.page-nav[hidden]{display:none!important}.page-nav--prev{left:12px}.page-nav--next{right:12px}.list-panel__overlay{z-index:calc(var(--z-overlay) - 1);position:fixed;inset:0}.list-panel{top:var(--header-height);right:var(--space-3);z-index:var(--z-overlay);width:280px;max-height:calc(100vh - var(--header-height) - var(--space-4));background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);flex-direction:column;display:flex;position:fixed;overflow:hidden}.list-panel[hidden]{display:none}.list-panel__header{padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--color-border);flex-shrink:0;justify-content:space-between;align-items:center;display:flex}.list-panel__title{font-size:var(--font-size-base);font-weight:var(--font-weight-bold);color:var(--color-text);margin:0}.list-panel__close{font-size:var(--font-size-xl);cursor:pointer;color:var(--color-text-secondary);padding:var(--space-1);border-radius:var(--radius-sm);transition:color var(--duration-fast) var(--easing-default), background var(--duration-fast) var(--easing-default);background:0 0;border:none;line-height:1}.list-panel__close:hover{color:var(--color-primary-700);background:var(--color-primary-50)}.list-panel__list{flex:1;margin:0;padding:0;list-style:none;overflow-y:auto}.list-panel__year{border-bottom:1px solid var(--color-border)}.list-panel__year:last-child{border-bottom:none}.list-panel__year-summary{padding:var(--space-2) var(--space-4);font-size:var(--font-size-sm);font-weight:var(--font-weight-bold);color:var(--color-text-secondary);cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;list-style:none;display:flex}.list-panel__year-summary::-webkit-details-marker{display:none}.list-panel__year-summary:before{content:"▸";margin-right:var(--space-2);transition:transform var(--duration-fast) var(--easing-default);font-size:.7em;display:inline-block}.list-panel__year-summary:hover{background:var(--color-bg-subtle)}.list-panel__year[open]>.list-panel__year-summary:before{transform:rotate(90deg)}.list-panel__month:last-child{border-bottom:none}.list-panel__month-summary{padding:var(--space-2) var(--space-4) var(--space-2) var(--space-6);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text);cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;list-style:none;display:flex}.list-panel__month-summary::-webkit-details-marker{display:none}.list-panel__month-summary:before{content:"▸";margin-right:var(--space-2);transition:transform var(--duration-fast) var(--easing-default);font-size:.6em;display:inline-block}.list-panel__month-summary:hover{background:var(--color-bg-subtle)}.list-panel__month[open]>.list-panel__month-summary:before{transform:rotate(90deg)}.list-panel__date{padding:var(--space-2) var(--space-4) var(--space-2) var(--space-8);font-size:var(--font-size-sm);cursor:pointer;color:var(--color-text);transition:background var(--duration-fast) var(--easing-default), color var(--duration-fast) var(--easing-default)}.list-panel__date:hover{background:var(--color-primary-50);color:var(--color-primary-700)}.list-panel__date.list-panel__date--active{background:var(--color-primary-100);color:var(--color-primary-800);font-weight:var(--font-weight-bold)}@media (width>=768px){.list-panel{width:320px}}
