@import"https://fonts.googleapis.com/css2?family=DM+Serif+Display:ital@0;1&family=Lora:ital,wght@0,400;0,500;0,600;1,400;1,500&family=Playfair+Display:ital,wght@0,400;0,500;1,400&family=Source+Sans+3:wght@400;600&display=swap";*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}body{min-height:100vh;line-height:var(--leading-normal)}img,video,canvas,svg{display:block;max-width:100%}input,button,textarea,select{font:inherit;color:inherit}button{cursor:pointer;border:none;background:none}a{color:inherit;text-decoration:none}ul,ol{list-style:none}h1,h2,h3,h4,h5,h6{font-weight:var(--weight-semibold);line-height:var(--leading-tight)}:root{--color-bg-primary: #0d0d0d;--color-bg-secondary: #141414;--color-bg-surface: #1a1a1a;--color-bg-elevated: #222222;--color-bg-hover: #2a2a2a;--color-text-primary: #f0f0f0;--color-text-secondary: #999999;--color-text-muted: #555555;--color-text-inverse: #111111;--color-border: #2a2a2a;--color-border-subtle: #1c1c1c;--color-accent: #cfa75e;--color-accent-hover: #dbb978;--color-accent-muted: rgba(207, 167, 94, .12);--color-neutral: #cccccc;--color-success: #4ade80;--color-warning: #d4a84b;--color-danger: #f87171;--color-palette-default: #f0f0f0;--color-palette-blue: #60a5fa;--color-palette-green: #4ade80;--color-palette-grey: #999999;--color-chart-line: var(--color-accent);--color-chart-glow: rgba(207, 167, 94, .25);--color-pace-warning: #d4a84b;--color-pace-ok: #4ade80;--color-souvenir-pulse: var(--color-accent);--font-ui: "Source Sans 3", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-writing: "Lora", "Georgia", "Cambria", serif;--font-display: "DM Serif Display", "Georgia", serif;--font-heading: "Playfair Display", "Georgia", serif;--font-mono: "SF Mono", "Fira Code", "Cascadia Code", monospace;--text-xs: .75rem;--text-sm: .8125rem;--text-base: .9375rem;--text-lg: 1.125rem;--text-xl: 1.5rem;--text-2xl: 2rem;--leading-tight: 1.3;--leading-normal: 1.6;--leading-relaxed: 1.8;--weight-normal: 400;--weight-medium: 500;--weight-semibold: 600;--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-6: 1.5rem;--space-8: 2rem;--space-12: 3rem;--space-16: 4rem;--radius-sm: 1px;--radius-md: 2px;--radius-lg: 2px;--radius-xl: 3px;--radius-full: 9999px;--shadow-sm: 0 1px 4px rgba(0, 0, 0, .5);--shadow-md: 0 4px 16px rgba(0, 0, 0, .5);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .6);--transition-fast: .12s ease;--transition-base: .2s ease;--transition-slow: .35s ease;--z-header: 100;--z-toolbar: 50;--z-dropdown: 60;--z-modal: 1000;--z-tooltip: 999;--content-max-width: 720px;--editor-min-height: 60vh}[data-theme=light]{--color-bg-primary: #ffffff;--color-bg-secondary: #f4f4f4;--color-bg-surface: #f4f4f4;--color-bg-elevated: #ffffff;--color-bg-hover: #e8e8e8;--color-text-primary: #111111;--color-text-secondary: #666666;--color-text-muted: #999999;--color-text-inverse: #f0f0f0;--color-border: #e0e0e0;--color-border-subtle: #eeeeee;--color-accent: #a8843d;--color-accent-hover: #8a6a2e;--color-accent-muted: rgba(168, 132, 61, .1);--color-neutral: #888888;--shadow-sm: 0 1px 4px rgba(0, 0, 0, .08);--shadow-md: 0 4px 16px rgba(0, 0, 0, .1);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .12);--color-chart-glow: rgba(168, 132, 61, .2);--color-palette-default: #111111;--color-palette-blue: #2563eb;--color-palette-green: #16a34a;--color-palette-grey: #666666}body{font-family:var(--font-ui);font-size:var(--text-base);font-weight:var(--weight-normal);color:var(--color-text-primary);background-color:var(--color-bg-primary);transition:background-color var(--transition-base),color var(--transition-base)}::selection{background:var(--color-accent-muted);color:var(--color-text-primary)}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--color-text-muted)}:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px;border-radius:var(--radius-sm)}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}#root{min-height:100vh;display:flex;flex-direction:column}.app-header{position:fixed;top:0;left:0;right:0;z-index:var(--z-header);height:48px;display:flex;align-items:center;justify-content:space-between;padding:0 var(--space-4);background-color:var(--color-bg-primary);border-bottom:1px solid var(--color-border-subtle);transition:background-color var(--transition-base),border-color var(--transition-base)}.app-title{font-family:var(--font-display);font-size:var(--text-sm);font-weight:var(--weight-medium);color:var(--color-text-muted);letter-spacing:.08em;text-transform:uppercase;-webkit-user-select:none;user-select:none}.header-actions{display:flex;align-items:center;gap:var(--space-2)}.theme-toggle{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:var(--radius-md);color:var(--color-text-muted);transition:color var(--transition-fast),background-color var(--transition-fast)}.theme-toggle:hover{color:var(--color-text-secondary);background-color:var(--color-bg-hover)}.auth-status{color:var(--color-text-muted);font-size:var(--text-sm);margin-right:var(--space-2)}.auth-btn,.header-actions .btn-secondary{padding:.25rem .5rem;font-size:var(--text-sm);border-radius:var(--radius-sm);cursor:pointer}.header-actions .btn-primary{background:var(--color-accent);color:#fff;border:none}.header-actions .btn-secondary{background:transparent;color:var(--color-text-muted);border:1px solid var(--color-text-muted)}.header-actions .btn-secondary:hover{color:var(--color-text-secondary);border-color:var(--color-text-secondary)}.app-body{display:grid;grid-template-columns:220px 1fr 220px;grid-template-areas:"left center right";min-height:100vh;padding-top:48px}.sidebar{position:sticky;top:48px;height:calc(100vh - 48px);overflow-y:auto;padding:var(--space-4);border-right:1px solid var(--color-border-subtle);background-color:var(--color-bg-primary);transition:background-color var(--transition-base),border-color var(--transition-base)}.sidebar--left{grid-area:left;display:flex;flex-direction:column;justify-content:space-between}.sidebar--right{grid-area:right;border-right:none;border-left:1px solid var(--color-border-subtle);display:flex;flex-direction:column;justify-content:flex-start}.editor-column{grid-area:center;min-height:calc(100vh - 48px);padding:0 var(--space-6) var(--space-8);border-left:1px solid var(--color-border-subtle);border-right:1px solid var(--color-border-subtle)}.section-placeholder{border:1px dashed var(--color-border);border-radius:var(--radius-lg);padding:var(--space-6);display:flex;align-items:center;justify-content:center;color:var(--color-text-muted);font-size:var(--text-sm);font-weight:var(--weight-medium);letter-spacing:.02em;transition:border-color var(--transition-base)}.section-placeholder--editor{min-height:80vh}.section-placeholder--sidebar{min-height:200px}.pacing-word-count{padding-top:var(--space-8);text-align:center;font-size:var(--text-sm);color:var(--color-text-muted)}.editor-container{width:100%;max-width:var(--content-max-width);margin:0 auto}.write-space-editor{min-height:var(--editor-min-height);outline:none;font-family:var(--font-writing);font-size:var(--text-lg);line-height:var(--leading-relaxed);color:var(--color-text-primary);padding-top:var(--space-4);padding-bottom:var(--space-16)}.write-space-editor--typewriter{padding-bottom:50vh}.write-space-editor p{margin-top:0;margin-bottom:var(--space-6)}.write-space-editor h1,.write-space-editor h2,.write-space-editor h3,.write-space-editor h4{font-family:var(--font-ui);color:var(--color-text-primary);margin-top:var(--space-8);margin-bottom:var(--space-4);line-height:var(--leading-tight);font-weight:var(--weight-semibold)}.write-space-editor h1{font-size:var(--text-2xl)}.write-space-editor h2{font-size:var(--text-xl)}.write-space-editor p.is-editor-empty:first-child:before{color:var(--color-text-muted);content:attr(data-placeholder);float:left;height:0;pointer-events:none}.write-space-editor *::selection{background-color:var(--color-accent-muted)}.tiptap-fake-selection{background-color:var(--color-accent-muted)}.editor-toolbar{display:flex;align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-2);background-color:var(--color-bg-primary);border-bottom:1px solid var(--color-border);position:sticky;top:48px;z-index:var(--z-toolbar);margin-left:calc(-1 * var(--space-6));margin-right:calc(-1 * var(--space-6))}.menu-button{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:var(--radius-md);color:var(--color-text-primary);background-color:transparent;font-family:var(--font-ui);font-size:var(--text-base);transition:all var(--transition-fast);cursor:pointer}.menu-button:hover{background-color:var(--color-bg-hover)}.menu-button.is-active{background-color:var(--color-accent-muted);color:var(--color-accent)}.menu-divider{width:1px;height:20px;background-color:var(--color-border);margin:0 var(--space-1)}.font-size-control{display:flex;align-items:center;background-color:var(--color-bg-primary);overflow:hidden}.font-size-step{width:24px;height:24px;background-color:var(--color-bg-elevated);border:none;color:var(--color-text-primary);font-size:var(--text-base);cursor:pointer;transition:color var(--transition-fast);flex-shrink:0}.font-size-step:hover{background-color:var(--color-bg-hover);color:var(--color-text-primary)}.font-size-input{width:60px;height:32px;background:transparent;border:none;color:var(--color-text-primary);font-family:var(--font-ui);font-size:var(--text-sm);text-align:center;outline:none;padding:0 var(--space-1)}.font-size-input::-webkit-outer-spin-button,.font-size-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.font-size-input[type=number]{-moz-appearance:textfield;appearance:textfield}.font-size-wrapper{position:relative}.font-size-dropdown{position:absolute;top:calc(100% + 6px);left:0;width:100%;display:flex;flex-direction:column;background-color:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-md);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);z-index:var(--z-dropdown);padding:var(--space-1);gap:2px;animation:dropdown-in .12s ease-out}.font-size-option{width:100%;height:28px;background:transparent;border:none;border-radius:var(--radius-sm);color:var(--color-text-primary);font-family:var(--font-ui);font-size:var(--text-sm);cursor:pointer;transition:background-color var(--transition-fast),color var(--transition-fast)}.font-size-option:hover{background-color:var(--color-bg-hover)}.font-size-option.is-selected{background-color:var(--color-accent-muted);color:var(--color-accent)}.font-family-wrapper{position:relative}.font-family-btn{width:auto;min-width:60px;padding:0 var(--space-2);font-size:var(--text-sm)}.font-family-dropdown{position:absolute;top:calc(100% + 6px);left:0;min-width:140px;display:flex;flex-direction:column;background-color:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-md);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);z-index:var(--z-dropdown);padding:var(--space-1);gap:2px;animation:dropdown-in .12s ease-out}.font-family-option{width:100%;height:32px;background:transparent;border:none;border-radius:var(--radius-sm);color:var(--color-text-primary);font-size:var(--text-sm);text-align:left;padding:0 var(--space-2);cursor:pointer;transition:background-color var(--transition-fast)}.font-family-option:hover{background-color:var(--color-bg-hover)}.font-family-option.is-selected{background-color:var(--color-accent-muted);color:var(--color-accent)}.line-height-wrapper{position:relative}.line-height-btn{font-size:var(--text-xs);width:auto;min-width:36px;padding:0 var(--space-1);letter-spacing:.01em}.line-height-dropdown{left:50%;transform:translate(-50%);width:auto;min-width:60px;animation:palette-in .12s ease-out}.copy-btn{margin-left:auto}.color-palette-wrapper{position:relative}.color-palette{position:absolute;top:calc(100% + 6px);left:50%;transform:translate(-50%);display:flex;gap:var(--space-2);padding:var(--space-2) var(--space-3);background-color:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);z-index:var(--z-dropdown);animation:palette-in .12s ease-out}@keyframes dropdown-in{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}@keyframes palette-in{0%{opacity:0;transform:translate(-50%) translateY(-4px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.color-swatch{width:22px;height:22px;border-radius:var(--radius-full);border:2px solid transparent;cursor:pointer;transition:transform var(--transition-fast),border-color var(--transition-fast),box-shadow var(--transition-fast);position:relative}.color-swatch:hover{transform:scale(1.2);border-color:var(--color-text-muted)}.color-swatch.is-selected{border-color:var(--color-text-primary);box-shadow:0 0 0 2px var(--color-bg-elevated),0 0 0 3px var(--color-text-muted)}.pacing-module{display:flex;flex-direction:column;background:var(--color-bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-md);padding:var(--space-4);margin:var(--space-3) 0}.pacing-header{display:flex;justify-content:space-between;align-items:center;cursor:pointer;-webkit-user-select:none;user-select:none}.pacing-title{font-size:var(--text-base);font-weight:var(--weight-medium);margin:0;color:var(--color-text-primary);border-bottom:1px solid var(--color-border-subtle);padding-bottom:var(--space-2);flex:1}.pacing-chevron{display:inline-block;width:7px;height:7px;border-right:1.5px solid var(--color-text-muted);border-bottom:1.5px solid var(--color-text-muted);transform:rotate(-45deg);transition:transform var(--transition-base);flex-shrink:0;margin-bottom:var(--space-2)}.pacing-chevron--open{transform:rotate(45deg)}.pacing-body{display:grid;grid-template-rows:0fr;transition:grid-template-rows var(--transition-base)}.pacing-body--open{grid-template-rows:1fr}.pacing-body-inner{overflow:hidden;display:flex;flex-direction:column;gap:var(--space-4);padding-top:var(--space-3)}.pacing-form{display:flex;flex-direction:column;gap:var(--space-3)}.form-group input{background:var(--color-bg-secondary);border:1px solid var(--color-border);color:var(--color-text-primary);padding:var(--space-2);border-radius:var(--radius-sm);font-family:var(--font-ui);font-size:var(--text-sm);outline:none;transition:border-color var(--transition-fast)}.form-group input:focus{border-color:var(--color-text-muted)}.pacing-actions{display:flex;flex-direction:column;gap:var(--space-2);margin-top:var(--space-2)}.btn-start,.btn-end,.btn-clear{padding:var(--space-2) var(--space-4);border:none;border-radius:var(--radius-md);font-size:var(--text-sm);font-weight:var(--weight-medium);cursor:pointer;transition:opacity var(--transition-fast),transform var(--transition-fast),background-color var(--transition-fast)}.btn-start{background-color:var(--color-text-primary);color:var(--color-bg-primary)}.btn-start:disabled{opacity:.5;cursor:not-allowed}.btn-start:not(:disabled):hover{opacity:.9}.btn-start:not(:disabled):active{transform:scale(.98)}.btn-end{background-color:var(--color-bg-hover);color:var(--color-text-primary);border:1px solid var(--color-border)}.btn-end:hover{background-color:var(--color-border-subtle)}.btn-end:active{transform:scale(.98)}.btn-clear{background-color:transparent;color:var(--color-text-muted);border:1px solid transparent}.btn-clear:hover{color:var(--color-text-primary);background-color:var(--color-bg-hover)}.btn-clear:active{transform:scale(.98)}.pacing-active{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-4);margin-top:var(--space-4);padding:var(--space-6) 0;border-radius:var(--radius-lg);background:var(--color-bg-secondary);border:1px solid var(--color-border-subtle)}.timer-display{font-size:3rem;font-weight:var(--weight-bold);font-variant-numeric:tabular-nums;color:var(--color-text-primary);line-height:1}.pacing-active-stats{font-size:var(--text-sm);color:var(--color-text-muted)}.pace-indicator-container{display:flex;align-items:center;justify-content:center;gap:var(--space-2);margin-top:var(--space-2)}.pace-label{font-size:var(--text-xs);font-family:var(--font-ui);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.1em;font-weight:var(--weight-bold)}.pace-circle{width:14px;height:14px;border-radius:50%;border:2px solid transparent;transition:background-color var(--transition-base),border-color var(--transition-base),box-shadow var(--transition-base)}.pace-circle.color-yellow{border-color:var(--color-pace-warning)}.pace-circle.color-green{border-color:var(--color-pace-ok)}.pace-circle.fill-yellow{background-color:var(--color-pace-warning)}.pace-circle.fill-green{background-color:var(--color-pace-ok)}.pace-circle.pulse.color-yellow{animation:pulse-yellow 1.5s infinite}.pace-circle.pulse.color-green{animation:pulse-green 1.5s infinite}@keyframes pulse-yellow{0%{box-shadow:0 0 #d4a84bb3}70%{box-shadow:0 0 0 8px #d4a84b00}to{box-shadow:0 0 #d4a84b00}}@keyframes pulse-green{0%{box-shadow:0 0 #4ade80b3}70%{box-shadow:0 0 0 8px #4ade8000}to{box-shadow:0 0 #4ade8000}}.activity-chart-container{width:100%;box-sizing:border-box;padding:var(--space-4);background:var(--color-bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-md);margin:var(--space-3) 0}.activity-chart-svg{width:100%;height:100%;overflow:visible}.activity-chart-line{fill:none;stroke:var(--color-chart-line);stroke-width:2.5px;stroke-linecap:round;stroke-linejoin:round;filter:drop-shadow(0 0 6px var(--color-chart-glow))}.activity-chart-axis-y path.domain{stroke:var(--color-border-subtle)}.activity-chart-axis-y .tick line{stroke:var(--color-border-subtle)}.activity-chart-axis-y .tick text{fill:var(--color-text-muted);font-size:.75rem;font-family:var(--font-mono)}.activity-chart-header{display:flex;justify-content:space-between;align-items:center;cursor:pointer;-webkit-user-select:none;user-select:none}.activity-chart-chevron{display:inline-block;width:7px;height:7px;border-right:1.5px solid var(--color-text-muted);border-bottom:1.5px solid var(--color-text-muted);transform:rotate(-45deg);transition:transform var(--transition-base);flex-shrink:0;margin-bottom:var(--space-2)}.activity-chart-chevron--open{transform:rotate(45deg)}.activity-chart-body{display:grid;grid-template-rows:0fr;transition:grid-template-rows var(--transition-base)}.activity-chart-body--open{grid-template-rows:1fr}.activity-chart-body-inner{overflow:hidden;min-height:0}.activity-chart-area{height:160px;padding-top:var(--space-3);box-sizing:border-box;position:relative}.activity-chart-title{font-size:var(--text-base);font-weight:var(--weight-medium);margin:0;color:var(--color-text-primary);border-bottom:1px solid var(--color-border-subtle);padding-bottom:var(--space-2)}.activity-chart-current-value{font-size:1.25rem;font-weight:700;font-family:var(--font-mono);color:var(--color-chart-line)}.souvenir-module{display:flex;flex-direction:column;gap:var(--space-4);padding:var(--space-4);background:var(--color-bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-md);margin:var(--space-3) 0}.souvenir-title{font-family:var(--font-heading);font-size:var(--text-base);font-weight:var(--weight-medium);margin:0;color:var(--color-text-primary);border-bottom:1px solid var(--color-border-subtle);padding-bottom:var(--space-2)}.souvenir-idle{font-size:var(--text-sm);color:var(--color-text-muted);margin:0;line-height:1.5}.souvenir-recording{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-sm);color:var(--color-text-muted)}.souvenir-recording-dot{width:8px;height:8px;border-radius:50%;background-color:var(--color-souvenir-pulse);animation:souvenir-pulse 2s ease-in-out infinite;flex-shrink:0}@keyframes souvenir-pulse{0%,to{opacity:1}50%{opacity:.3}}.souvenir-complete{display:flex;flex-direction:column;gap:var(--space-3)}.souvenir-stat{display:flex;flex-direction:column;gap:var(--space-1)}.souvenir-stat-value{font-size:var(--text-lg);font-weight:var(--weight-bold);color:var(--color-text-primary);font-variant-numeric:tabular-nums}.souvenir-stat-label{font-size:var(--text-xs);font-family:var(--font-ui);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em}.souvenir-actions{display:flex;flex-direction:column;gap:var(--space-2);margin-top:var(--space-2)}.btn-download{padding:var(--space-2) var(--space-4);border:none;border-radius:var(--radius-md);font-size:var(--text-sm);font-weight:var(--weight-medium);cursor:pointer;background-color:var(--color-text-primary);color:var(--color-bg-primary);transition:opacity var(--transition-fast),transform var(--transition-fast)}.btn-download:hover{opacity:.9}.btn-download:active{transform:scale(.98)}.btn-dismiss{padding:var(--space-2) var(--space-4);border:1px solid transparent;border-radius:var(--radius-md);font-size:var(--text-sm);font-weight:var(--weight-medium);cursor:pointer;background-color:transparent;color:var(--color-text-muted);transition:color var(--transition-fast),background-color var(--transition-fast),transform var(--transition-fast)}.btn-dismiss:hover{color:var(--color-text-primary);background-color:var(--color-bg-hover)}.btn-dismiss:active{transform:scale(.98)}.record-module-root{display:flex;flex-direction:column;padding:var(--space-4);font-family:var(--font-ui);background:var(--color-bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-md);margin:auto 0 var(--space-3) 0}.record-card{width:auto}.record-card-header{cursor:pointer;-webkit-user-select:none;user-select:none}.record-card-title-row{display:flex;justify-content:space-between;align-items:center}.record-card-title-end{display:flex;align-items:center;gap:var(--space-2)}.record-chevron{display:inline-block;width:7px;height:7px;border-right:1.5px solid var(--color-text-muted);border-bottom:1.5px solid var(--color-text-muted);transform:rotate(-45deg);transition:transform var(--transition-base);flex-shrink:0}.record-chevron--open{transform:rotate(45deg)}.record-card-body{display:grid;grid-template-rows:0fr;transition:grid-template-rows var(--transition-base)}.record-card-body--open{grid-template-rows:1fr}.record-card-body-inner{overflow:hidden;padding-top:var(--space-3)}.record-card-title{font-family:var(--font-heading);font-size:var(--text-base);font-weight:var(--weight-medium);margin:0;color:var(--color-text-primary);border-bottom:1px solid var(--color-border-subtle);padding-bottom:var(--space-2)}.record-card-total{color:var(--color-success);font-size:var(--text-xs);font-weight:var(--weight-semibold)}.record-card-subtitle-row{display:flex;justify-content:space-between;align-items:center;margin-top:2px}.record-card-subtitle,.record-card-label{color:var(--color-text-muted);font-size:var(--text-xs)}.record-error{color:var(--color-danger);font-size:var(--text-xs);padding:var(--space-3) 0;text-align:center}.record-loading{color:var(--color-text-muted);font-size:var(--text-xs);padding:var(--space-6) 0;text-align:center}.record-day-labels{display:flex;margin-left:40px;margin-bottom:2px;gap:3px}.record-day-label{font-size:7px;color:var(--color-text-muted);text-align:center}.record-graph-scroll{overflow-y:auto;max-height:320px;border-radius:var(--radius-md)}.record-legend{display:flex;align-items:center;gap:4px;margin-top:8px;justify-content:flex-end}.record-legend-label{color:var(--color-text-muted);font-size:var(--text-xs)}.record-legend-label--left{margin-right:4px}.record-legend-label--right{margin-left:4px}.record-legend-cell{width:11px;height:11px;border-radius:2px}.record-card .section-placeholder--sidebar{min-height:120px;border:none}.record-day-label{width:13px}.record-tooltip{position:fixed;background:var(--color-bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-2) var(--space-3);font-size:var(--text-xs);color:var(--color-text-primary);pointer-events:none;z-index:999;white-space:nowrap;box-shadow:var(--shadow-md)}.writing-session-module{display:flex;flex-direction:column;background:var(--color-bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-md);padding:var(--space-4);margin:var(--space-3) 0}.writing-session-header{display:flex;justify-content:space-between;align-items:center;cursor:pointer;-webkit-user-select:none;user-select:none}.writing-session-title{font-size:var(--text-base);font-weight:var(--weight-medium);margin:0;color:var(--color-text-primary);border-bottom:1px solid var(--color-border-subtle);padding-bottom:var(--space-2);flex:1}.writing-session-chevron{display:inline-block;width:7px;height:7px;border-right:1.5px solid var(--color-text-muted);border-bottom:1.5px solid var(--color-text-muted);transform:rotate(45deg);transition:transform var(--transition-base);flex-shrink:0;margin-bottom:var(--space-2)}.writing-session-chevron--open{transform:rotate(-135deg)}.writing-session-body{display:grid;grid-template-rows:0fr;transition:grid-template-rows var(--transition-base)}.writing-session-body--open{grid-template-rows:1fr}.writing-session-body-inner{overflow:hidden;padding-top:var(--space-3)}.writing-session-form{display:flex;flex-direction:column;gap:var(--space-3)}.form-group{display:flex;flex-direction:column;gap:var(--space-1)}.form-group label{font-size:var(--text-xs);font-family:var(--font-ui);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em}.word-count-display{font-size:2rem;font-weight:var(--weight-bold);color:var(--color-text-primary);font-variant-numeric:tabular-nums;line-height:1}.form-group textarea{background:var(--color-bg-secondary);border:1px solid var(--color-border);color:var(--color-text-primary);padding:var(--space-2);border-radius:var(--radius-sm);font-family:var(--font-ui);font-size:var(--text-sm);outline:none;resize:vertical;transition:border-color var(--transition-fast)}.form-group textarea:focus{border-color:var(--color-text-muted)}.form-group textarea:disabled{opacity:.5;cursor:not-allowed}.writing-session-actions{display:flex;flex-direction:column;gap:var(--space-2);margin-top:var(--space-2)}.btn-submit{padding:var(--space-2) var(--space-4);border:none;border-radius:var(--radius-md);font-size:var(--text-sm);font-weight:var(--weight-medium);cursor:pointer;background-color:var(--color-text-primary);color:var(--color-bg-primary);transition:opacity var(--transition-fast),transform var(--transition-fast)}.btn-submit:disabled{opacity:.5;cursor:not-allowed}.btn-submit:not(:disabled):hover{opacity:.9}.btn-submit:not(:disabled):active{transform:scale(.98)}.status-success{color:var(--color-success);font-size:var(--text-sm);text-align:center;animation:fadeIn var(--transition-base)}.status-error{color:var(--color-danger);font-size:var(--text-sm);text-align:center;animation:fadeIn var(--transition-base)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.writing-session-module .section-placeholder--sidebar{min-height:80px;border:none}.auth-dialog-backdrop{position:fixed;top:0;left:0;width:100vw;height:100vh;background:#00000080;display:flex;justify-content:center;align-items:center;z-index:var(--z-modal)}.auth-dialog{background:var(--color-bg-surface);padding:2rem;border-radius:var(--radius-md);width:100%;max-width:400px;border:1px solid var(--color-border);position:relative;box-shadow:var(--shadow-md)}.auth-dialog h2{margin-top:0;margin-bottom:1.5rem;color:var(--color-text-primary)}.auth-dialog-close{position:absolute;top:1rem;right:1rem;background:none;border:none;font-size:1.5rem;cursor:pointer;color:var(--color-text-muted)}.auth-dialog-close:hover{color:var(--color-text-primary)}.auth-dialog .form-group{margin-bottom:1rem}.auth-dialog input{width:100%;padding:.5rem;background:var(--color-bg-primary);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-primary);box-sizing:border-box}.auth-dialog-actions{display:flex;justify-content:flex-end;gap:1rem;margin-top:1.5rem}.auth-error{color:var(--color-danger);font-size:.875rem;margin-top:.5rem}.auth-dialog .btn-primary{background:var(--color-accent);color:var(--color-text-inverse);border:none;padding:.5rem 1rem;border-radius:var(--radius-sm);cursor:pointer}.auth-dialog .btn-primary:hover:not(:disabled){filter:brightness(1.1)}.auth-dialog .btn-secondary{background:var(--color-bg-hover);color:var(--color-text-primary);border:1px solid var(--color-border);padding:.5rem 1rem;border-radius:var(--radius-sm);cursor:pointer}.auth-dialog .btn-secondary:hover:not(:disabled){background:var(--color-border)}.auth-dialog button:disabled{opacity:.5;cursor:not-allowed}.error-boundary{padding:2rem;color:var(--color-danger)}
