:root{font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;line-height:1.5;font-weight:400;color:#0f172a;background-color:#f8fafc;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;min-width:320px;min-height:100vh;background:#f8fafc}#root{min-height:100vh}:root{--bg-primary: #ffffff;--bg-secondary: #f8f9fa;--bg-card: #ffffff;--text-primary: #202124;--text-secondary: #5f6368;--border-color: #dadce0;--shadow-sm: 0 1px 2px 0 rgba(60, 64, 67, .3), 0 1px 3px 1px rgba(60, 64, 67, .15);--shadow-md: 0 2px 4px 0 rgba(60, 64, 67, .3), 0 4px 8px 3px rgba(60, 64, 67, .15);--shadow-lg: 0 4px 8px 0 rgba(60, 64, 67, .3), 0 8px 16px 6px rgba(60, 64, 67, .15);--color-primary: #1a73e8;--color-primary-hover: #1557b0;--color-secondary: #ea4335;--color-secondary-hover: #c5221f;--color-success: #34a853;--color-warning: #fbbc04;--search-bg: #ffffff;--search-border: #dfe1e5;--search-border-hover: rgba(223, 225, 229, .5);--search-shadow: 0 1px 6px rgba(32, 33, 36, .28);--search-shadow-hover: 0 2px 8px rgba(32, 33, 36, .28)}[data-theme=dark]{color-scheme:dark;--bg-primary: #202124;--bg-secondary: #292a2d;--bg-card: #303134;--text-primary: #e8eaed;--text-secondary: #9aa0a6;--border-color: #5f6368;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .6), 0 1px 3px 1px rgba(0, 0, 0, .4);--shadow-md: 0 2px 4px 0 rgba(0, 0, 0, .6), 0 4px 8px 3px rgba(0, 0, 0, .4);--shadow-lg: 0 4px 8px 0 rgba(0, 0, 0, .6), 0 8px 16px 6px rgba(0, 0, 0, .4);--color-primary: #8ab4f8;--color-primary-hover: #aecbfa;--color-secondary: #f28b82;--color-secondary-hover: #f6aea9;--color-success: #81c995;--color-warning: #fdd663;--search-bg: #303134;--search-border: #5f6368;--search-border-hover: rgba(95, 99, 104, .5);--search-shadow: 0 1px 6px rgba(0, 0, 0, .5);--search-shadow-hover: 0 2px 8px rgba(0, 0, 0, .5)}[data-theme=dark] .table-loading{background-color:#202124b3}[data-theme=dark] input[type=date],[data-theme=dark] input[type=month],[data-theme=dark] select{color-scheme:dark}[data-theme=dark] input[type=date]::-webkit-calendar-picker-indicator,[data-theme=dark] input[type=month]::-webkit-calendar-picker-indicator{filter:invert(1);opacity:.85}*{margin:0;padding:0;box-sizing:border-box}html{height:100%}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:var(--bg-primary);color:var(--text-primary);font-size:16px;line-height:1.6;transition:background-color .3s ease,color .3s ease;height:100%;overflow:hidden}#root{height:100%}.App{min-height:100vh;display:flex;flex-direction:column;height:100%}.header{padding:6px 10px;display:flex;flex-direction:column;align-items:stretch;gap:8px;background-color:var(--bg-primary);border-bottom:1px solid var(--border-color);flex-wrap:wrap}.topbar-header{width:100%;display:flex;align-items:center;justify-content:flex-start;gap:8px}.topbar-menu{display:flex;align-items:center;gap:12px;justify-content:space-between;min-width:220px;width:100%;overflow:hidden;max-height:600px;opacity:1;transition:max-height .3s ease,opacity .3s ease}.topbar-menu.is-collapsed{max-height:0;opacity:0;pointer-events:none}.topbar-title{font-size:1.2rem;font-weight:600;letter-spacing:-.4px;white-space:nowrap}.topbar-toggle{border:1px solid var(--border-color);background-color:var(--bg-secondary);color:var(--text-primary);font-size:.7rem;padding:4px 10px;border-radius:999px;cursor:pointer;line-height:1}.topbar-toggle:hover{border-color:var(--color-primary);color:var(--color-primary)}.topbar-actions{display:flex;flex-wrap:wrap;gap:8px;align-items:center}.topbar-actions .btn{padding:6px 8px;font-size:.8rem;min-width:0}.topbar-session{display:flex;gap:10px;align-items:center}.topbar-session .btn{padding:6px 8px;font-size:.8rem;min-width:0}.theme-toggle{background-color:transparent;border:2px solid var(--border-color);color:var(--text-primary);font-size:.8rem;font-weight:500;padding:4px 8px;border-radius:24px;cursor:pointer;transition:all .2s ease;font-family:inherit;min-width:0}.theme-toggle:hover{background-color:var(--bg-secondary);border-color:var(--text-secondary);box-shadow:var(--shadow-sm)}.theme-toggle:active{transform:scale(.98)}.theme-toggle:focus{outline:3px solid var(--color-primary);outline-offset:2px}.main-container{flex:1;display:flex;flex-direction:column;align-items:stretch;padding:6px 12px 12px;max-width:100%;margin:0 auto;width:100%;min-height:0}.logo{font-size:clamp(2.5rem,4vw,3.5rem);font-weight:300;color:var(--text-primary);margin-bottom:16px;text-align:center;letter-spacing:-1px}.search-container{width:100%;max-width:100%;border-radius:16px;border:1px solid var(--border-color);background-color:var(--bg-card);padding:12px 14px;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:12px}.search-section{display:flex;flex-direction:column;gap:6px;margin-bottom:10px}.search-bar-wrapper{display:flex;align-items:center;width:100%;border:1px solid var(--border-color);border-radius:12px;background-color:var(--bg-primary);box-shadow:none;transition:all .2s ease;overflow:hidden}.search-bar{flex:1;padding:12px 14px;font-size:.95rem;border:none;background-color:transparent;color:var(--text-primary);transition:all .2s ease;font-family:inherit}.search-bar-wrapper:hover{border-color:var(--color-primary)}.search-bar:focus{outline:none}.search-bar::placeholder{color:var(--text-secondary);opacity:.8}.search-bar-wrapper:focus-within{border-color:var(--color-primary);box-shadow:0 2px 8px #1a73e840}.search-filter{border:none;background-color:var(--bg-secondary);color:var(--text-primary);font-size:.85rem;padding:8px 10px;cursor:pointer;font-family:inherit;border-left:1px solid var(--border-color)}.search-filter:focus{outline:none}.filter-panel{display:flex;flex-direction:column;gap:10px}.filter-toggle-row{display:flex;align-items:center;justify-content:flex-start;width:100%;padding-left:4px;gap:8px;flex-wrap:wrap}.filter-toggle-btn{border:1px solid var(--border-color);background-color:var(--bg-secondary);color:var(--text-primary);font-size:.7rem;padding:3px 10px;min-width:36px;border-radius:999px;cursor:pointer;line-height:1}.filter-toggle-btn:hover{border-color:var(--color-primary);color:var(--color-primary)}.controls-footer{display:flex;flex-direction:column;align-items:stretch;gap:6px}.controls-summary{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}.stats-panel{margin-top:0;padding:0;border:none;background-color:transparent;display:flex;align-items:center;gap:8px;font-size:.85rem;color:var(--text-secondary)}.stats-title{font-weight:600;color:var(--text-primary)}.stats-value{color:var(--text-secondary)}.column-visibility-count{font-size:.75rem;color:var(--text-secondary)}.column-picker{border:1px solid var(--border-color);background-color:var(--bg-secondary);border-radius:10px;padding:10px;display:flex;flex-direction:column;gap:8px}.column-picker-actions{display:flex;gap:8px;align-items:center}.column-picker-list{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:8px}.column-picker-item{display:inline-flex;align-items:center;gap:8px;font-size:.82rem;color:var(--text-primary);padding:6px 10px;border-radius:999px;border:1px solid var(--border-color);background-color:var(--bg-primary);cursor:pointer;transition:all .2s ease}.column-picker-item input{accent-color:var(--color-primary)}.column-picker-item input:checked+span{color:var(--color-primary);font-weight:600}.column-picker-item:hover{border-color:var(--color-primary)}.filter-list{display:flex;flex-wrap:nowrap;gap:8px;align-items:center;overflow-x:auto;padding-bottom:4px;-webkit-overflow-scrolling:touch}.filter-actions{display:flex;gap:8px;align-items:center}.filter-row{display:flex;flex-wrap:nowrap;gap:8px;align-items:center;flex:0 0 auto;padding:6px 8px;border-radius:10px;border:1px solid var(--border-color);background-color:var(--bg-secondary)}.filter-row .filter-select,.filter-row .filter-input,.filter-row .filter-date-range,.filter-row .filter-remove{flex:0 0 auto}.filter-select,.filter-input{padding:6px 8px;font-size:.85rem;border:1px solid var(--border-color);border-radius:6px;background-color:var(--bg-primary);color:var(--text-primary);font-family:inherit}.filter-input{min-width:160px}.filter-date-range{display:flex;align-items:center;gap:6px}.filter-range-sep{font-size:.85rem;color:var(--text-secondary)}.filter-btn{padding:4px 8px;font-size:.75rem;min-width:0}.filter-remove{padding:4px 8px;font-size:.8rem;min-width:0}.pager-loading{font-size:.78rem;color:var(--text-secondary)}.filter-toggle-row .pager-loading{margin-right:4px}.pager-actions{display:flex;gap:6px}.pager-btn{padding:2px 6px;font-size:.72rem;min-width:0}.btn{padding:16px 32px;font-size:1.15rem;font-weight:500;border:none;border-radius:8px;cursor:pointer;transition:all .2s ease;font-family:inherit;box-shadow:var(--shadow-sm);min-width:160px}.btn.filter-btn{padding:6px 10px;font-size:.85rem;min-width:0}.btn.filter-remove{padding:2px 6px;font-size:.7rem;min-width:0}.btn.pager-btn{padding:3px 8px;font-size:.75rem;min-width:0}.btn.import-toggle{padding:8px 12px;font-size:.85rem;min-width:0;background-color:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border-color);box-shadow:none}.btn.import-toggle:hover{box-shadow:var(--shadow-sm)}.btn.import-toggle.is-active{background-color:var(--color-primary);color:#fff;border-color:var(--color-primary)}.btn.import-toggle.is-active:hover{background-color:var(--color-primary-hover)}.btn:active{transform:scale(.98)}.btn:focus{outline:3px solid var(--color-primary);outline-offset:2px}.btn-primary{background-color:var(--color-primary);color:#fff}.btn-primary:hover{background-color:var(--color-primary-hover);box-shadow:var(--shadow-md)}.btn-secondary{background-color:var(--color-secondary);color:#fff}.btn-secondary:hover{background-color:var(--color-secondary-hover);box-shadow:var(--shadow-md)}.table-container{width:100%;overflow:auto;background-color:var(--bg-card);border-radius:12px;box-shadow:var(--shadow-md);height:100%;-webkit-overflow-scrolling:touch}.table-wrapper{position:relative;width:100%;height:100%}.table-loading{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background-color:#ffffffa6;color:var(--text-primary);font-size:.95rem;z-index:6}table{width:max-content;min-width:100%;border-collapse:collapse;font-size:.85rem;table-layout:auto;line-height:1.2}thead{background-color:var(--bg-secondary);position:sticky;top:0;z-index:10}th{padding:6px 10px;text-align:left;font-weight:600;color:var(--text-primary);border-bottom:2px solid var(--border-color);white-space:nowrap}.select-all-checkbox{width:20px;height:20px;cursor:pointer;accent-color:var(--color-primary)}.select-all-checkbox:disabled{opacity:.6;cursor:not-allowed}.draggable-column{cursor:grab;-webkit-user-select:none;user-select:none;position:relative;touch-action:none}.draggable-column.is-dragging{opacity:.6}.draggable-column.is-over-before:before,.draggable-column.is-over-after:after{content:"";position:absolute;top:15%;bottom:15%;width:3px;background-color:var(--color-primary);border-radius:2px}.draggable-column.is-over-before:before{left:0}.draggable-column.is-over-after:after{right:0}.drag-handle{margin-right:6px;color:var(--text-secondary);font-weight:600}.column-type-icon{margin-left:6px;font-size:.8rem;opacity:.7}td{padding:6px 10px;border-bottom:1px solid var(--border-color);border-right:1px solid var(--border-color);color:var(--text-primary);vertical-align:middle}td:last-child{border-right:none}.cell-content{white-space:nowrap}.cell-link{background:none;border:none;padding:0;color:var(--text-primary);font:inherit;text-align:left;cursor:pointer;white-space:nowrap}.cell-link:hover{color:var(--color-primary);text-decoration:underline}tbody tr{transition:background-color .2s ease;background-color:var(--bg-primary)}tbody tr:hover{background-color:var(--bg-secondary)}tbody tr:nth-child(2n){background-color:var(--bg-secondary)}tbody tr:last-child td{border-bottom:none}.items-section{flex:1;min-height:0;width:100%}.table-btn{padding:4px 8px;font-size:.8rem;margin-right:6px;border:1px solid var(--border-color);background-color:var(--bg-card);color:var(--text-primary);border-radius:6px;cursor:pointer;transition:all .2s ease}.table-btn:hover{background-color:var(--bg-secondary);box-shadow:var(--shadow-sm)}.table-btn:focus{outline:2px solid var(--color-primary);outline-offset:1px}.table-btn.delete{color:var(--color-secondary);border-color:var(--color-secondary)}.table-btn.table-btn-icon{padding:4px 8px;font-size:1rem;min-width:0}.permission-disabled{opacity:.5;cursor:not-allowed}.permission-disabled.btn:active,.permission-disabled.table-btn:active{transform:none}.permission-disabled.table-btn,.permission-disabled.table-btn:hover{background-color:var(--bg-card);color:var(--text-secondary);border-color:var(--border-color);box-shadow:none}.permission-disabled.table-btn.delete:hover{background-color:var(--bg-card);color:var(--text-secondary)}.permission-disabled.btn{box-shadow:none;background-color:var(--bg-secondary);color:var(--text-secondary)}.permission-disabled.btn:hover{background-color:var(--bg-secondary);color:var(--text-secondary)}.row-actions{display:flex;align-items:center;gap:6px}.row-actions .table-btn{position:relative}.memo-count{position:absolute;top:-6px;right:-6px;min-width:16px;height:16px;padding:0 4px;border-radius:999px;background-color:var(--color-secondary);color:#fff;font-size:.65rem;display:inline-flex;align-items:center;justify-content:center;box-shadow:var(--shadow-sm)}.has-tooltip:after{content:attr(data-tooltip);position:absolute;bottom:calc(100% + 6px);left:50%;transform:translate(-50%);background-color:#111;color:#fff;padding:4px 8px;border-radius:6px;font-size:.7rem;white-space:nowrap;opacity:0;pointer-events:none;transition:opacity .15s ease;z-index:20}.has-tooltip:before{content:"";position:absolute;bottom:calc(100% + 2px);left:50%;transform:translate(-50%);border:4px solid transparent;border-top-color:#111;opacity:0;pointer-events:none;transition:opacity .15s ease;z-index:19}.has-tooltip:hover:after,.has-tooltip:hover:before{opacity:1}.table-btn.delete:hover{background-color:var(--color-secondary);color:#fff}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#0009;display:flex;justify-content:center;align-items:center;z-index:1000;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal{background-color:var(--bg-card);border-radius:12px;padding:32px;box-shadow:var(--shadow-lg);max-width:500px;width:90%;max-height:85vh;overflow-y:auto;animation:slideUp .3s ease}.modal-wide{max-width:1100px;width:96%}.modal-wide .modal-form{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:16px}.modal-wide .modal-actions{grid-column:1 / -1;margin-top:8px}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.modal h2{font-size:1.8rem;margin-bottom:24px;color:var(--text-primary);font-weight:500}.modal-form{display:flex;flex-direction:column;gap:20px}.form-group{display:flex;flex-direction:column;gap:8px}.form-group label{font-size:1.1rem;font-weight:500;color:var(--text-primary)}.form-group input{padding:14px 16px;font-size:1.1rem;border:2px solid var(--border-color);border-radius:8px;background-color:var(--bg-primary);color:var(--text-primary);transition:all .2s ease;font-family:inherit}.form-group input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #1a73e81a}.form-group input::placeholder{color:var(--text-secondary)}.modal-actions{display:flex;gap:12px;margin-top:24px;justify-content:flex-end}.modal-actions .btn{min-width:120px}.btn-cancel{background-color:transparent;color:var(--text-primary);border:2px solid var(--border-color)}.btn-cancel:hover{background-color:var(--bg-secondary)}.import-modal{max-width:720px;width:94%}.import-dropzone{border:2px dashed var(--border-color);border-radius:12px;padding:20px;text-align:center;background-color:var(--bg-primary);transition:border-color .2s ease,background-color .2s ease}.import-dropzone.is-active{border-color:var(--color-primary);background-color:var(--bg-secondary)}.import-dropzone-title{font-size:1rem;font-weight:500;color:var(--text-primary)}.import-dropzone-actions{display:flex;justify-content:center;gap:8px;flex-wrap:wrap;margin:12px 0}.import-dropzone-hint{font-size:.85rem;color:var(--text-secondary)}.import-file-list{margin-top:16px;display:flex;flex-direction:column;gap:8px;max-height:200px;overflow-y:auto}.import-file-item{display:flex;justify-content:space-between;gap:12px;padding:8px 12px;border-radius:8px;background-color:var(--bg-secondary);font-size:.9rem}.import-file-name{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.import-file-meta{font-size:.8rem;color:var(--text-secondary)}.import-options{margin-top:16px;padding:12px;border-radius:10px;background-color:var(--bg-secondary);display:flex;align-items:center;justify-content:space-between;gap:12px}.import-option-label{font-weight:500;color:var(--text-primary)}.btn.import-action{padding:8px 14px;font-size:.85rem;min-width:0}.memo-layout{display:grid;grid-template-columns:minmax(220px,1fr) minmax(280px,2fr);gap:16px;margin-bottom:20px}.modal-wide .memo-form{display:flex;flex-direction:column;gap:16px}.memo-list{background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:10px;padding:12px;max-height:260px;overflow-y:auto}.memo-titles{list-style:none;display:flex;flex-direction:column;gap:6px;margin:0;padding:0}.memo-title{width:100%;text-align:left;border:none;background-color:transparent;padding:8px 10px;border-radius:8px;cursor:pointer;color:var(--text-primary);font-family:inherit;display:flex;flex-direction:column;gap:4px}.memo-title-text{font-weight:600}.memo-date{font-size:.75rem;color:var(--text-secondary)}.memo-title.active{background-color:var(--bg-primary);box-shadow:var(--shadow-sm)}.memo-edit-title,.memo-edit-date{width:100%;padding:8px 10px;font-size:1rem;border:1px solid var(--border-color);border-radius:6px;background-color:var(--bg-primary);color:var(--text-primary)}.memo-edit-date{margin-top:6px}.memo-edit-content{width:100%;min-height:140px;padding:12px;border:1px solid var(--border-color);border-radius:8px;background-color:var(--bg-primary);color:var(--text-primary);font-size:1rem;resize:vertical}.memo-actions{display:flex;gap:8px;align-items:center}.memo-action-btn{padding:4px 8px;font-size:.85rem;line-height:1;min-width:auto}.memo-detail{border:1px solid var(--border-color);border-radius:10px;padding:12px;background-color:var(--bg-primary);min-height:160px;display:flex;flex-direction:column;gap:12px}.memo-detail-header{display:flex;align-items:center;justify-content:space-between;gap:12px}.memo-detail-header h3{margin:0;font-size:1.1rem}.memo-content{white-space:pre-wrap;color:var(--text-primary);font-size:.95rem;line-height:1.5}.memo-empty{color:var(--text-secondary);font-size:.9rem}.memo-delete{padding:6px 10px;font-size:.85rem;min-width:0}.row-detail-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px;margin-bottom:16px}.row-detail-item{border:1px solid var(--border-color);border-radius:10px;padding:10px;background-color:var(--bg-secondary)}.row-detail-label{font-size:.75rem;color:var(--text-secondary);margin-bottom:4px}.row-detail-value{font-size:.9rem;color:var(--text-primary);word-break:break-word}.text-center{text-align:center}.mt-1{margin-top:8px}.mt-2{margin-top:16px}.mt-3{margin-top:24px}.mb-1{margin-bottom:8px}.mb-2{margin-bottom:16px}.mb-3{margin-bottom:24px}@media(max-width:768px){.header{align-items:stretch}.topbar-menu{width:100%}.topbar-actions{flex-wrap:nowrap;overflow-x:auto;padding-bottom:4px;-webkit-overflow-scrolling:touch}.topbar-actions .btn{white-space:nowrap}.search-bar-wrapper{flex-direction:column;align-items:stretch;border-radius:12px;overflow:visible;position:relative}.search-filter{position:absolute;right:8px;top:50%;transform:translateY(-50%);width:auto;border:1px solid var(--border-color);border-radius:999px;padding:6px 8px}.search-bar{border-radius:12px;padding-right:96px}.filter-row{flex-direction:column;align-items:stretch}.filter-select,.filter-input{width:100%}.filter-date-range{width:100%;flex-direction:column;align-items:stretch}.filter-toggle-row{align-items:flex-start;justify-content:flex-start;padding-left:2px}.column-picker-list{grid-template-columns:1fr;max-height:45vh;overflow-y:auto;padding-right:4px;-webkit-overflow-scrolling:touch}.column-picker-item{width:100%}.memo-layout{grid-template-columns:1fr}.memo-list{max-height:200px}.controls-summary{justify-content:flex-start}.stats-panel{font-size:.72rem;gap:6px}.stats-title,.stats-value{font-size:.72rem}.search-bar{font-size:.95rem;padding:12px 14px}.btn{font-size:.9rem;padding:10px 14px;min-width:0}th,td{padding:6px 8px;font-size:.8rem}.modal{padding:24px}.modal h2{font-size:1.5rem}}@media(max-width:480px){.search-bar{font-size:.9rem;padding:10px 12px}.btn{font-size:.85rem;padding:8px 10px;width:auto}.topbar-menu{width:100%;flex-direction:column;align-items:stretch;gap:6px}.topbar-actions,.topbar-session{width:100%;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:6px}.topbar-actions .btn,.topbar-session .btn,.theme-toggle{justify-content:center;text-align:center;padding:6px 8px;font-size:.8rem;border-radius:8px;width:100%}th,td{padding:5px 6px;font-size:.75rem}.theme-toggle{font-size:.9rem;padding:6px 12px;min-width:0}}*:focus-visible{outline:3px solid var(--color-primary);outline-offset:2px}button:disabled{opacity:.5;cursor:not-allowed}@media(prefers-reduced-motion:reduce){*{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}
