.auth-page{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:24px 16px;background-color:var(--color-bg)}.auth-topbar{position:fixed;top:0;right:0;display:flex;align-items:center;gap:8px;padding:12px 16px;z-index:100}.auth-card{width:100%;max-width:440px;background:var(--color-surface);border-radius:16px;padding:40px 40px 32px;box-shadow:var(--shadow-card);border:1px solid var(--color-border)}.auth-card--wide{width:150%;max-width:none;margin-left:-25%}@media (max-width: 900px){.auth-card--wide{width:100%;margin-left:0}}@media (max-width: 480px){.auth-card{padding:32px 24px 24px;border-radius:12px}}.auth-logo{text-align:center;margin-bottom:28px}.auth-logo-icon{display:inline-flex;align-items:center;justify-content:center;width:56px;height:56px;background:var(--color-primary);border-radius:14px;margin-bottom:12px}.auth-logo-icon svg{width:32px;height:32px;color:#fff}.auth-app-name{font-size:1.125rem;font-weight:700;color:var(--color-text);letter-spacing:.02em}.auth-tagline{font-size:.8125rem;color:var(--color-text-muted);margin-top:2px}.auth-title{font-size:1.5rem;font-weight:700;color:var(--color-text);margin-bottom:6px}.auth-subtitle{font-size:.9375rem;color:var(--color-text-muted);margin-bottom:28px}.auth-form{display:flex;flex-direction:column;gap:16px}.form-group{display:flex;flex-direction:column;gap:6px}.form-label{font-size:.875rem;font-weight:500;color:var(--color-text)}.form-label-optional{font-size:.75rem;color:var(--color-text-muted);font-weight:400;margin-left:4px}.form-input{width:100%;padding:10px 14px;font-size:.9375rem;color:var(--color-text);background-color:var(--color-input-bg);border:1.5px solid var(--color-border);border-radius:8px;transition:border-color .15s ease,box-shadow .15s ease;-moz-appearance:none;appearance:none;-webkit-appearance:none}.form-input::placeholder{color:var(--color-text-muted);opacity:.7}.form-input:hover:not(:disabled){border-color:var(--color-text-muted)}.form-input:focus{outline:none;border-color:var(--color-border-focus);box-shadow:var(--shadow-input-focus)}.form-input--error{border-color:var(--color-error)}.form-input--error:focus{box-shadow:0 0 0 3px #dc262633}.form-input:disabled{opacity:.5;cursor:not-allowed}.form-error{font-size:.8125rem;color:var(--color-error);display:flex;align-items:center;gap:4px}.input-wrapper{position:relative;display:flex;align-items:center}.input-wrapper .form-input{padding-right:44px}.input-icon-btn{position:absolute;right:12px;background:none;border:none;cursor:pointer;padding:2px;color:var(--color-text-muted);display:flex;align-items:center;border-radius:4px;transition:color .15s}.input-icon-btn:hover{color:var(--color-text)}.form-checkbox-group{display:flex;align-items:flex-start;gap:10px}.form-checkbox{width:18px;height:18px;min-width:18px;border:1.5px solid var(--color-border);border-radius:4px;background:var(--color-input-bg);cursor:pointer;accent-color:var(--color-primary);margin-top:2px}.form-checkbox-label{font-size:.875rem;color:var(--color-text);cursor:pointer;-webkit-user-select:none;user-select:none}.form-checkbox-label a{color:var(--color-primary);font-weight:500}.form-row{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:8px}.register-two-col{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}@media (max-width: 900px){.register-two-col{grid-template-columns:1fr}}.captcha-inline{display:flex;align-items:center;justify-content:flex-start;flex-wrap:wrap;gap:10px}.captcha-question{width:240px;height:56px;min-height:56px;display:flex;align-items:center;justify-content:center;padding:0;border:1px solid var(--color-border);border-radius:6px;background:#fff;color:var(--color-text);font-weight:600;letter-spacing:.04em}.captcha-image{display:block;width:240px;height:56px;object-fit:cover}.captcha-answer-input{width:240px;height:56px;margin:0}.captcha-refresh-btn{width:auto;min-width:104px;padding:10px 12px}@media (max-width: 900px){.captcha-refresh-btn{width:100%}}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:11px 20px;font-size:.9375rem;font-weight:600;border-radius:8px;border:none;cursor:pointer;transition:background-color .15s ease,opacity .15s ease,transform .1s ease;text-decoration:none;white-space:nowrap}.btn:active:not(:disabled){transform:scale(.98)}.btn:disabled{opacity:.55;cursor:not-allowed}.btn--primary{background:var(--color-primary);color:var(--color-primary-fg);width:100%}.btn--primary:hover:not(:disabled){background:var(--color-primary-hover)}.btn--ghost{background:transparent;color:var(--color-text-muted);border:1.5px solid var(--color-border);padding:8px 14px;font-size:.875rem;font-weight:500}.btn--ghost:hover:not(:disabled){background:var(--color-surface-hover);color:var(--color-text)}.oauth-divider{display:flex;align-items:center;gap:12px;margin:8px 0;color:var(--color-text-muted);font-size:.8125rem}.oauth-divider:before,.oauth-divider:after{content:"";flex:1;height:1px;background:var(--color-divider)}.oauth-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}.btn--oauth{background:var(--color-oauth-bg);color:var(--color-oauth-text);border:1.5px solid var(--color-oauth-border);padding:9px 12px;font-size:.8125rem;font-weight:500;border-radius:8px;width:100%;cursor:not-allowed;opacity:.6;display:flex;align-items:center;justify-content:center;gap:6px;transition:none}.btn--oauth svg{width:18px;height:18px;flex-shrink:0}.alert{padding:14px 16px;border-radius:8px;font-size:.9rem;display:flex;gap:10px;align-items:flex-start}.alert--success{background:var(--color-success-bg);color:var(--color-success);border:1px solid var(--color-success)}.alert--error{background:var(--color-error-bg);color:var(--color-error);border:1px solid var(--color-error)}.alert__title{font-weight:600;margin-bottom:2px}.auth-footer{text-align:center;margin-top:20px;font-size:.9rem;color:var(--color-text-muted)}.auth-footer a{font-weight:500}.code-input{text-transform:uppercase;letter-spacing:.15em;font-size:1.25rem;text-align:center;font-weight:600}.theme-toggle{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:8px;border:1.5px solid var(--color-border);background:var(--color-surface);color:var(--color-text-muted);cursor:pointer;transition:background .15s,color .15s,border-color .15s}.theme-toggle:hover{background:var(--color-surface-hover);color:var(--color-text);border-color:var(--color-text-muted)}.theme-toggle svg{width:18px;height:18px}.lang-switcher{display:flex;gap:4px;align-items:center}.lang-flag-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;font-size:1.25rem;line-height:1;background:transparent;border:2px solid transparent;border-radius:8px;cursor:pointer;opacity:.45;transition:opacity .15s,border-color .15s;padding:0;box-sizing:border-box}.lang-flag-btn:hover{opacity:.75}.lang-flag-btn--active{opacity:1;border-color:var(--color-primary)}.lang-flag-btn:focus-visible{outline:none;border-color:var(--color-border-focus);box-shadow:var(--shadow-input-focus)}.spinner{width:18px;height:18px;border:2px solid rgba(255,255,255,.35);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.resend-link{text-align:center;margin-top:12px;font-size:.875rem;color:var(--color-text-muted)}.resend-link button{background:none;border:none;color:var(--color-primary);font-size:.875rem;font-weight:500;cursor:pointer;padding:0;text-decoration:underline}.resend-link button:hover{opacity:.8}.app-layout{min-height:100vh;display:flex;flex-direction:column;background:var(--color-bg)}.app-header{background:var(--color-surface);border-bottom:1px solid var(--color-border);box-shadow:0 1px 4px #0000000f;position:sticky;top:0;z-index:100}.app-header__inner{width:90%;max-width:90%;margin:0 auto;padding:0 24px;height:60px;display:flex;align-items:center;justify-content:space-between;gap:16px}.app-header__brand{display:flex;align-items:center;gap:10px;text-decoration:none;color:var(--color-text);font-weight:700;font-size:1rem;letter-spacing:.02em;flex-shrink:0}.app-header__brand:hover{text-decoration:none;color:var(--color-primary)}.app-header__brand-icon{display:flex;align-items:center;justify-content:center;width:34px;height:34px;background:var(--color-primary);border-radius:8px;flex-shrink:0}.app-header__brand-icon svg{width:20px;height:20px;color:#fff}.app-header__right{display:flex;align-items:center;gap:12px}.app-header__user-control{display:flex;align-items:center}.app-header-callsign-select{height:36px;min-width:180px;max-width:260px;padding:0 10px;font-size:.85rem;color:var(--color-text);background:var(--color-input-bg);border:1.5px solid var(--color-border);border-radius:8px}.app-header-callsign-select:focus{outline:none;border-color:var(--color-border-focus);box-shadow:var(--shadow-input-focus)}.user-badge{display:flex;align-items:center;gap:8px;height:36px;padding:0 12px;border-radius:8px;background:var(--color-surface-hover);border:1px solid var(--color-border);box-sizing:border-box}.user-badge__avatar{width:28px;height:28px;border-radius:50%;background:var(--color-primary);color:#fff;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700;flex-shrink:0}.user-badge__info{display:flex;flex-direction:column;line-height:1.2}.user-badge__callsign{font-size:.875rem;font-weight:600;color:var(--color-text)}.user-badge__role{font-size:.7rem;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em}.user-badge--guest .user-badge__avatar{background:var(--color-text-muted)}.user-badge--guest .user-badge__callsign{color:var(--color-text-muted);font-weight:400}.btn--logout{display:flex;align-items:center;gap:6px;height:36px;padding:0 12px;font-size:.8125rem;font-weight:500;color:var(--color-text-muted);background:transparent;border:1.5px solid var(--color-border);border-radius:8px;cursor:pointer;box-sizing:border-box;transition:color .15s,border-color .15s,background .15s}.btn--logout:hover{color:var(--color-error);border-color:var(--color-error);background:var(--color-error-bg)}.btn--logout svg{width:15px;height:15px}.app-main{flex:1;max-width:1200px;width:100%;margin:0 auto;padding:32px 24px}.app-main--wide{max-width:90%}.index-welcome{margin-bottom:32px}.index-welcome__title{font-size:1.75rem;font-weight:700;color:var(--color-text);margin-bottom:6px}.index-welcome__sub{font-size:1rem;color:var(--color-text-muted)}.index-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:16px}.index-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:12px;padding:24px;display:flex;flex-direction:column;gap:8px;box-shadow:var(--shadow-card);transition:border-color .15s,box-shadow .15s,transform .1s}a.index-card:hover{border-color:var(--color-primary);box-shadow:0 4px 24px #2563eb26;transform:translateY(-2px)}.index-card__icon{font-size:1.75rem}.index-card__title{font-size:1rem;font-weight:600;color:var(--color-text)}.index-card__desc{font-size:.875rem;color:var(--color-text-muted)}.badge-admin{display:inline-block;padding:2px 8px;background:var(--color-primary);color:#fff;font-size:.7rem;font-weight:700;border-radius:4px;text-transform:uppercase;letter-spacing:.05em}.guest-hero{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center;margin-bottom:48px;padding:40px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:16px;box-shadow:var(--shadow-card)}@media (max-width: 720px){.guest-hero{grid-template-columns:1fr;padding:28px 20px;gap:28px}.guest-hero__illustration{order:-1}}.guest-hero__content h1{font-size:1.75rem;font-weight:700;color:var(--color-text);margin-bottom:20px;line-height:1.3}.guest-hero__content h1 span{color:var(--color-primary)}.guest-hero__text{color:var(--color-text-muted);font-size:.9375rem;line-height:1.75;margin-bottom:14px}.guest-hero__actions{display:flex;gap:12px;margin-top:28px;flex-wrap:wrap}.guest-hero__illustration{display:flex;align-items:center;justify-content:center}.logbook-header{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px;margin-bottom:20px}.logbook-header__title{font-size:1.5rem;font-weight:700;color:var(--color-text)}.logbook-header__title span{font-size:.9rem;font-weight:400;color:var(--color-text-muted);margin-left:8px}.logbook-toolbar{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:16px}.logbook-search{flex:1;min-width:200px;max-width:320px;padding:8px 14px;font-size:.9rem;color:var(--color-text);background:var(--color-input-bg);border:1.5px solid var(--color-border);border-radius:8px;transition:border-color .15s,box-shadow .15s}.logbook-search:focus{outline:none;border-color:var(--color-border-focus);box-shadow:var(--shadow-input-focus)}.logbook-search::placeholder{color:var(--color-text-muted);opacity:.7}.logbook-table-wrap{overflow-x:auto;border-radius:12px;border:1px solid var(--color-border);box-shadow:var(--shadow-card);background:var(--color-surface)}.logbook-table{width:100%;border-collapse:collapse;font-size:.8375rem;white-space:nowrap}.logbook-table thead th{padding:10px 12px;text-align:left;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-muted);background:var(--color-surface-hover);border-bottom:1px solid var(--color-border);-webkit-user-select:none;user-select:none;cursor:pointer;white-space:nowrap}.logbook-table thead th:hover{color:var(--color-text)}.logbook-table thead th.sort-asc:after{content:" ▲";font-size:.65rem}.logbook-table thead th.sort-desc:after{content:" ▼";font-size:.65rem}.logbook-table tbody tr{border-bottom:1px solid var(--color-divider);transition:background .1s}.logbook-table tbody tr:last-child{border-bottom:none}.logbook-table tbody tr:hover{background:var(--color-surface-hover)}.logbook-table td{padding:8px 12px;color:var(--color-text);vertical-align:middle}.logbook-table td.td-callsign{font-weight:600;font-family:monospace;font-size:.9rem;letter-spacing:.04em;color:var(--color-primary)}.logbook-table td.td-logbook{font-size:.82rem;color:var(--color-text-muted, var(--color-text));white-space:nowrap;max-width:140px;overflow:hidden;text-overflow:ellipsis}.logbook-table td.td-datetime{font-family:monospace;color:var(--color-text-muted);font-size:.8rem}.logbook-table td.td-freq{font-family:monospace;font-size:.8rem}.band-badge{display:inline-block;padding:2px 7px;border-radius:4px;background:var(--color-surface-hover);border:1px solid var(--color-border);font-size:.72rem;font-weight:600;font-family:monospace;color:var(--color-text-muted)}.mode-badge{display:inline-block;padding:2px 7px;border-radius:4px;font-size:.72rem;font-weight:700;letter-spacing:.05em}.mode-badge--cw{background:#fef3c7;color:#92400e}.mode-badge--ssb,.mode-badge--usb,.mode-badge--lsb{background:#dbeafe;color:#1e40af}.mode-badge--fm{background:#dcfce7;color:#166534}.mode-badge--am{background:#fce7f3;color:#9d174d}.mode-badge--ft8,.mode-badge--ft4{background:#ede9fe;color:#5b21b6}.mode-badge--rtty{background:#ffedd5;color:#9a3412}.mode-badge--other{background:var(--color-surface-hover);color:var(--color-text-muted)}[data-theme=dark] .mode-badge--cw{background:#451a03;color:#fcd34d}[data-theme=dark] .mode-badge--ssb,[data-theme=dark] .mode-badge--usb,[data-theme=dark] .mode-badge--lsb{background:#1e3a5f;color:#93c5fd}[data-theme=dark] .mode-badge--fm{background:#14532d;color:#86efac}[data-theme=dark] .mode-badge--am{background:#500724;color:#f9a8d4}[data-theme=dark] .mode-badge--ft8,[data-theme=dark] .mode-badge--ft4{background:#2e1065;color:#c4b5fd}[data-theme=dark] .mode-badge--rtty{background:#431407;color:#fdba74}.qsl-badge{display:inline-flex;align-items:center;justify-content:center;min-width:32px;padding:3px 7px;border-radius:5px;font-size:.72rem;font-weight:700;letter-spacing:.04em;cursor:pointer;border:1.5px solid transparent;transition:opacity .15s,transform .1s;-webkit-user-select:none;user-select:none}.qsl-badge:hover{opacity:.8}.qsl-badge:active{transform:scale(.95)}.qsl-badge--none{background:var(--color-surface-hover);border-color:var(--color-border);color:var(--color-text-muted)}.qsl-badge--s{background:#dbeafe;border-color:#93c5fd;color:#1e40af}.qsl-badge--r{background:#ffedd5;border-color:#fdba74;color:#9a3412}.qsl-badge--sr{background:#dcfce7;border-color:#86efac;color:#166534}[data-theme=dark] .qsl-badge--s{background:#1e3a5f;border-color:#3b82f6;color:#93c5fd}[data-theme=dark] .qsl-badge--r{background:#431407;border-color:#f97316;color:#fdba74}[data-theme=dark] .qsl-badge--sr{background:#14532d;border-color:#22c55e;color:#86efac}.qsl-badge[title]{position:relative}.tbl-icon-btn{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:6px;border:1.5px solid var(--color-border);background:var(--color-surface);color:var(--color-text-muted);cursor:pointer;transition:color .15s,border-color .15s,background .15s;flex-shrink:0}.tbl-icon-btn:hover{color:var(--color-primary);border-color:var(--color-primary);background:var(--color-surface-hover)}.tbl-icon-btn--active{color:var(--color-primary);border-color:var(--color-primary);background:color-mix(in srgb,var(--color-primary) 10%,transparent)}.tbl-icon-btn svg{width:15px;height:15px}.tbl-icon-btn--audio.tbl-icon-btn--active{color:var(--color-success);border-color:var(--color-success);background:color-mix(in srgb,var(--color-success) 10%,transparent)}.public-link-btn{display:inline-flex;align-items:center;gap:4px;padding:3px 8px;border-radius:5px;border:1.5px solid var(--color-success);background:color-mix(in srgb,var(--color-success) 10%,transparent);color:var(--color-success);font-size:.72rem;font-weight:600;cursor:pointer;text-decoration:none;transition:opacity .15s}.public-link-btn:hover{opacity:.75;text-decoration:none}.public-link-btn svg{width:12px;height:12px}.tbl-checkbox{width:16px;height:16px;cursor:pointer;accent-color:var(--color-primary)}.logbook-empty{text-align:center;padding:56px 24px;color:var(--color-text-muted)}.logbook-empty svg{width:48px;height:48px;opacity:.35;margin-bottom:12px}.logbook-empty__title{font-size:1rem;font-weight:600;margin-bottom:4px;color:var(--color-text)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;display:flex;align-items:center;justify-content:center;z-index:1000;padding:16px}.modal{background:var(--color-surface);border:1px solid var(--color-border);border-radius:14px;width:100%;max-width:440px;box-shadow:0 20px 60px #0000004d;overflow:hidden}.modal__header{display:flex;align-items:center;justify-content:space-between;padding:18px 20px 14px;border-bottom:1px solid var(--color-border)}.modal__title{font-size:1rem;font-weight:700;color:var(--color-text)}.modal__close{background:none;border:none;cursor:pointer;padding:4px;color:var(--color-text-muted);border-radius:6px;display:flex;align-items:center}.modal__close:hover{color:var(--color-text);background:var(--color-surface-hover)}.modal__close svg{width:18px;height:18px}.modal__body{padding:20px;display:flex;flex-direction:column;gap:16px}.modal__footer{display:flex;justify-content:flex-end;gap:10px;padding:14px 20px;border-top:1px solid var(--color-border)}.dropzone{border:2px dashed var(--color-border);border-radius:10px;padding:32px 20px;text-align:center;cursor:pointer;transition:border-color .2s,background .2s;color:var(--color-text-muted)}.dropzone:hover,.dropzone--active{border-color:var(--color-primary);background:color-mix(in srgb,var(--color-primary) 5%,transparent);color:var(--color-text)}.dropzone svg{width:36px;height:36px;margin-bottom:8px;opacity:.5}.dropzone__label{font-size:.875rem;font-weight:500;display:block;margin-bottom:4px}.dropzone__hint{font-size:.75rem;opacity:.7}.img-preview{width:100%;max-height:240px;object-fit:contain;border-radius:8px;border:1px solid var(--color-border);background:var(--color-bg)}.audio-preview{display:flex;align-items:center;gap:10px;padding:10px 14px;background:var(--color-surface-hover);border-radius:8px;border:1px solid var(--color-border);font-size:.875rem;color:var(--color-text)}.audio-preview svg{width:20px;height:20px;color:var(--color-success);flex-shrink:0}.btn--camera{display:flex;align-items:center;justify-content:center;gap:6px;padding:9px 16px;background:var(--color-surface-hover);border:1.5px solid var(--color-border);border-radius:8px;font-size:.875rem;font-weight:500;color:var(--color-text-muted);cursor:pointer;transition:color .15s,border-color .15s}.btn--camera:hover{color:var(--color-text);border-color:var(--color-text-muted)}.btn--camera svg{width:16px;height:16px}.copy-toast{position:fixed;bottom:24px;left:50%;transform:translate(-50%);background:var(--color-text);color:var(--color-bg);padding:8px 20px;border-radius:8px;font-size:.875rem;font-weight:500;z-index:2000;animation:fadeInUp .2s ease,fadeOut .3s ease 1.5s forwards;pointer-events:none}@keyframes fadeInUp{0%{opacity:0;transform:translate(-50%) translateY(10px)}to{opacity:1;transform:translate(-50%) translateY(0)}}@keyframes fadeOut{to{opacity:0}}.logbook-count{font-size:.8rem;color:var(--color-text-muted);margin-left:auto;align-self:center}.logbook-body{--logbook-sidebar-width: 220px;--logbook-body-gap: 20px;--logbook-main-top-offset: 52px;display:flex;gap:var(--logbook-body-gap);align-items:flex-start}.logbook-sidebar{flex-shrink:0;width:var(--logbook-sidebar-width);background:var(--color-surface);border:1px solid var(--color-border);border-radius:12px;box-shadow:var(--shadow-card);padding:4px 0 8px;position:sticky;top:80px;margin-top:var(--logbook-main-top-offset)}.logbook-main{flex:1 1 auto;max-width:none;min-width:0}.logbook-sidebar--left{order:1}.logbook-main{order:2}.logbook-sidebar--right{order:3}@media (max-width: 1380px){.logbook-body{--logbook-body-gap: 14px;flex-direction:column}.logbook-main,.logbook-sidebar{order:initial;width:100%;max-width:100%;margin-top:0}.logbook-main{flex:1 1 auto}.logbook-sidebar{position:static;top:auto}}.sidebar-section{padding:10px 12px 12px;border-bottom:1px solid var(--color-divider)}.sidebar-section:last-of-type{border-bottom:none}.sidebar-section__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.sidebar-section__header span{font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-muted)}.sidebar-collapse-btn{display:flex;align-items:center;justify-content:space-between;background:none;border:none;padding:0;cursor:pointer;color:inherit;flex:1;text-align:left}.sidebar-collapse-btn:hover span{color:var(--color-text)}.sidebar-collapse-btn svg{color:var(--color-text-muted);flex-shrink:0}.sidebar-clear-btn{background:none;border:none;cursor:pointer;font-size:.68rem;color:var(--color-primary);padding:0;line-height:1}.sidebar-clear-btn:hover{text-decoration:underline}.sidebar-btn-grid{display:grid;grid-template-columns:1fr 1fr;gap:5px}.sidebar-btn-grid--3{grid-template-columns:1fr 1fr 1fr}.sidebar-filter-btn--group{justify-content:center;font-family:sans-serif;font-size:.72rem;letter-spacing:.04em}.sidebar-filter-btn{display:flex;align-items:center;justify-content:space-between;gap:4px;padding:5px 8px;border-radius:6px;border:1.5px solid var(--color-border);background:var(--color-bg);color:var(--color-text);font-size:.775rem;font-weight:600;font-family:monospace;cursor:pointer;transition:border-color .12s,background .12s,color .12s;white-space:nowrap;overflow:hidden}.sidebar-filter-btn:hover{border-color:var(--color-primary);background:color-mix(in srgb,var(--color-primary) 6%,transparent);color:var(--color-primary)}.sidebar-filter-btn--active{border-color:var(--color-primary);background:var(--color-primary);color:#fff}.sidebar-filter-btn--active:hover{background:color-mix(in srgb,var(--color-primary) 85%,black);color:#fff}.sidebar-filter-btn__count{font-size:.65rem;font-weight:700;opacity:.7;font-family:sans-serif}.sidebar-filter-btn--active .sidebar-filter-btn__count{opacity:.85}.sidebar-reset-btn{display:block;width:calc(100% - 24px);margin:8px 12px 2px;padding:6px 10px;font-size:.775rem;font-weight:500;color:var(--color-text-muted);background:none;border:1.5px solid var(--color-border);border-radius:7px;cursor:pointer;transition:color .15s,border-color .15s;text-align:center}.sidebar-reset-btn:hover{color:var(--color-error);border-color:var(--color-error)}.active-filter-tags{display:flex;flex-wrap:wrap;gap:6px;align-items:center}.filter-tag{display:inline-flex;align-items:center;gap:5px;padding:3px 9px;background:color-mix(in srgb,var(--color-primary) 12%,transparent);border:1px solid color-mix(in srgb,var(--color-primary) 40%,transparent);border-radius:20px;font-size:.75rem;font-weight:600;color:var(--color-primary);font-family:monospace}.filter-tag button{background:none;border:none;cursor:pointer;color:var(--color-primary);padding:0;line-height:1;font-size:.9rem;opacity:.7}.filter-tag button:hover{opacity:1}.td-center{text-align:center}.td-exch{font-family:monospace;font-size:.8rem;color:var(--color-text-muted)}.td-empty{color:var(--color-text-muted);opacity:.35;font-size:.75rem}.public-link-btn--audio{border-color:var(--color-success);background:color-mix(in srgb,var(--color-success) 10%,transparent);color:var(--color-success)}.modal--logbook{max-width:580px}.modal--logbooks{max-width:780px}.logbooks-loading,.logbooks-empty{text-align:center;padding:32px 16px;color:var(--color-text-muted);font-size:.9rem}.logbooks-table{width:100%;border-collapse:collapse;font-size:.8375rem}.logbooks-table thead th{padding:8px 10px;text-align:left;font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-muted);border-bottom:1px solid var(--color-border);white-space:nowrap}.logbooks-table tbody tr{border-bottom:1px solid var(--color-divider);transition:background .1s}.logbooks-table tbody tr:last-child{border-bottom:none}.logbooks-table tbody tr:hover{background:var(--color-surface-hover)}.logbooks-row--active{background:color-mix(in srgb,var(--color-primary) 6%,transparent)!important}.logbooks-table td{padding:8px 10px;color:var(--color-text);vertical-align:middle}.logbooks-name{font-weight:600;max-width:220px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.logbooks-count{font-weight:700;font-family:monospace;color:var(--color-primary)}.logbooks-actions{display:flex;gap:6px;justify-content:flex-end}.btn-icon-text{display:inline-flex;align-items:center;gap:5px;padding:5px 10px;border-radius:6px;font-size:.775rem;font-weight:600;cursor:pointer;border:1.5px solid;transition:opacity .15s;white-space:nowrap}.btn-icon-text--primary{border-color:var(--color-primary);background:color-mix(in srgb,var(--color-primary) 10%,transparent);color:var(--color-primary)}.btn-icon-text--ghost{border-color:var(--color-border);background:transparent;color:var(--color-text-muted)}.btn-icon-text--danger{border-color:var(--color-error);background:color-mix(in srgb,var(--color-error) 8%,transparent);color:var(--color-error)}.btn-icon-text:hover{opacity:.75}.btn--danger{display:flex;align-items:center;justify-content:center;padding:9px 20px;border-radius:9px;border:none;background:var(--color-error);color:#fff;font-size:.875rem;font-weight:600;cursor:pointer;transition:opacity .15s}.btn--danger:hover:not(:disabled){opacity:.85}.btn--danger:disabled{opacity:.45;cursor:default}.upload-panel{margin-top:16px;padding:16px;background:var(--color-surface-hover);border:1px solid var(--color-border);border-radius:10px;display:flex;flex-direction:column;gap:10px}.upload-panel__title{font-size:.875rem;color:var(--color-text-muted)}.upload-panel__title strong{color:var(--color-text)}.upload-result{padding:8px 12px;border-radius:7px;font-size:.8125rem;font-weight:500}.upload-result--ok{background:color-mix(in srgb,var(--color-success) 12%,transparent);color:var(--color-success);border:1px solid var(--color-success)}.upload-result--err{background:color-mix(in srgb,var(--color-error) 10%,transparent);color:var(--color-error);border:1px solid var(--color-error)}.pagination-bar{display:flex;align-items:center;justify-content:flex-end;gap:6px;margin-top:14px;flex-wrap:wrap}.pagination-btn{min-width:32px;height:32px;padding:0 8px;border-radius:7px;border:1.5px solid var(--color-border);background:var(--color-surface);color:var(--color-text);font-size:.875rem;cursor:pointer;transition:border-color .12s,background .12s;display:flex;align-items:center;justify-content:center}.pagination-btn:hover:not(:disabled){border-color:var(--color-primary);background:color-mix(in srgb,var(--color-primary) 8%,transparent);color:var(--color-primary)}.pagination-btn:disabled{opacity:.35;cursor:default}.pagination-info{font-size:.8125rem;color:var(--color-text-muted);padding:0 6px;white-space:nowrap}.pagination-size{padding:0 8px;height:32px;font-size:.875rem;color:var(--color-text);background:var(--color-input-bg);border:1.5px solid var(--color-border);border-radius:7px;cursor:pointer}.logbook-table-wrap--loading{opacity:.55;pointer-events:none;transition:opacity .2s}.sidebar-logbook-btn{display:flex;align-items:center;justify-content:space-between;gap:6px;width:100%;padding:5px 8px;border-radius:6px;border:1.5px solid var(--color-border);background:var(--color-bg);color:var(--color-text);font-size:.775rem;font-weight:500;cursor:pointer;text-align:left;transition:border-color .12s,background .12s,color .12s;margin-bottom:3px}.sidebar-logbook-btn:hover{border-color:var(--color-primary);background:color-mix(in srgb,var(--color-primary) 6%,transparent);color:var(--color-primary)}.sidebar-logbook-btn--active{border-color:var(--color-primary);background:var(--color-primary);color:#fff}.sidebar-logbook-btn--active:hover{background:color-mix(in srgb,var(--color-primary) 85%,black)}.sidebar-logbook-btn__name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.filter-tag--logbook{background:color-mix(in srgb,var(--color-success) 12%,transparent);border-color:color-mix(in srgb,var(--color-success) 40%,transparent);color:var(--color-success)}.filter-tag--logbook button{color:var(--color-success)}.modal--review{max-width:860px}.review-summary{display:flex;gap:16px;padding:10px 14px;background:var(--color-surface-hover);border-radius:8px;border:1px solid var(--color-border);font-size:.875rem;font-weight:600}.review-summary__ok{color:var(--color-success)}.review-summary__dup{color:var(--color-warning, #d97706)}.review-table{width:100%;border-collapse:collapse;font-size:.8rem}.review-table thead th{padding:7px 10px;text-align:left;font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-muted);border-bottom:2px solid var(--color-border);white-space:nowrap}.review-table tbody tr{border-bottom:1px solid var(--color-divider);transition:background .1s}.review-table tbody tr:last-child{border-bottom:none}.review-table tbody tr:hover{background:var(--color-surface-hover)}.review-row--selected{background:color-mix(in srgb,var(--color-primary) 7%,transparent)!important}.review-cell--check{width:36px;text-align:center;padding:6px 10px;vertical-align:middle}.review-cell{padding:6px 10px;vertical-align:middle;font-family:monospace;white-space:nowrap}.review-cell--incoming{color:var(--color-primary);border-left:3px solid var(--color-primary)}.review-cell--existing{color:var(--color-text-muted);border-left:3px solid var(--color-border)}.review-hint{font-size:.775rem;color:var(--color-text-muted);margin:0}.form-field{display:flex;flex-direction:column;gap:5px}.form-field__label{font-size:.8125rem;font-weight:600;color:var(--color-text)}.form-field__required{color:var(--color-error);margin-left:2px}.form-field__input{padding:8px 12px;font-size:.875rem;color:var(--color-text);background:var(--color-input-bg);border:1.5px solid var(--color-border);border-radius:8px;transition:border-color .15s,box-shadow .15s;width:100%;box-sizing:border-box}.form-field__input:focus{outline:none;border-color:var(--color-border-focus);box-shadow:var(--shadow-input-focus)}.form-field__textarea{padding:8px 12px;font-size:.8rem;font-family:monospace;color:var(--color-text);background:var(--color-input-bg);border:1.5px solid var(--color-border);border-radius:8px;resize:vertical;width:100%;box-sizing:border-box;transition:border-color .15s,box-shadow .15s}.form-field__textarea:focus{outline:none;border-color:var(--color-border-focus);box-shadow:var(--shadow-input-focus)}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}.dropzone--sm{padding:18px 16px}.dropzone--sm svg{width:24px;height:24px;margin-bottom:4px}.form-error{padding:8px 12px;background:color-mix(in srgb,var(--color-error) 10%,transparent);border:1px solid var(--color-error);border-radius:7px;font-size:.8125rem;color:var(--color-error)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-text-size-adjust:100%;scroll-behavior:smooth}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif;background-color:var(--color-bg);color:var(--color-text);line-height:1.6;min-height:100vh;transition:background-color .2s ease,color .2s ease}:focus-visible{outline:2px solid var(--color-border-focus);outline-offset:2px}:focus:not(:focus-visible){outline:none}h1,h2,h3{line-height:1.3;color:var(--color-text)}a{color:var(--color-primary);text-decoration:none}a:hover{text-decoration:underline}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.skip-link{position:absolute;top:-999px;left:0;padding:8px 16px;background:var(--color-primary);color:var(--color-primary-fg);font-weight:600;z-index:9999;border-radius:0 0 4px}.skip-link:focus{top:0}:root,[data-theme=light]{--color-bg: #f0f4f8;--color-surface: #ffffff;--color-surface-hover: #f8fafc;--color-primary: #2563eb;--color-primary-hover: #1d4ed8;--color-primary-fg: #ffffff;--color-text: #1a1a2e;--color-text-muted: #64748b;--color-border: #d1d5db;--color-border-focus: #2563eb;--color-error: #dc2626;--color-error-bg: #fef2f2;--color-success: #16a34a;--color-success-bg: #f0fdf4;--color-warning: #d97706;--color-input-bg: #ffffff;--color-divider: #e5e7eb;--color-oauth-bg: #ffffff;--color-oauth-border: #d1d5db;--color-oauth-text: #374151;--shadow-card: 0 4px 24px rgba(0, 0, 0, .08);--shadow-input-focus: 0 0 0 3px rgba(37, 99, 235, .25)}[data-theme=dark]{--color-bg: #0f172a;--color-surface: #1e293b;--color-surface-hover: #263347;--color-primary: #3b82f6;--color-primary-hover: #2563eb;--color-primary-fg: #ffffff;--color-text: #f1f5f9;--color-text-muted: #94a3b8;--color-border: #334155;--color-border-focus: #3b82f6;--color-error: #f87171;--color-error-bg: #3b1212;--color-success: #4ade80;--color-success-bg: #0a2a1a;--color-warning: #fbbf24;--color-input-bg: #0f172a;--color-divider: #334155;--color-oauth-bg: #1e293b;--color-oauth-border: #475569;--color-oauth-text: #e2e8f0;--shadow-card: 0 4px 24px rgba(0, 0, 0, .4);--shadow-input-focus: 0 0 0 3px rgba(59, 130, 246, .35)}
