*,:after,:before{box-sizing:border-box;margin:0;padding:0}:root{--color-bg:#fafafa;--color-surface:#ffffff;--color-border:#e5e7eb;--color-text:#111827;--color-text-secondary:#6b7280;--color-primary:#1e40af;--color-primary-hover:#1e3a8a;--color-accent:#2563eb;--color-danger:#dc2626;--color-success:#16a34a;--sidebar-width:240px;--topbar-height:56px}body,html{height:100%;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;color:var(--color-text);background:var(--color-bg);line-height:1.5}a{color:var(--color-accent);text-decoration:none}a:hover{text-decoration:underline}button{cursor:pointer;font-family:inherit}.app-layout{display:flex;min-height:100vh}.sidebar{width:var(--sidebar-width);background:var(--color-surface);border-right:1px solid var(--color-border);padding:1rem 0;position:fixed;top:0;left:0;bottom:0;overflow-y:auto}.sidebar-brand{padding:.5rem 1.25rem 1.5rem;font-size:1.125rem;font-weight:700;color:var(--color-primary)}.sidebar nav{display:flex;flex-direction:column;gap:2px}.sidebar nav a{display:block;padding:.5rem 1.25rem;color:var(--color-text-secondary);font-size:.875rem;font-weight:500;border-radius:0;text-decoration:none;transition:background .15s}.sidebar nav a:hover{background:var(--color-bg);color:var(--color-text);text-decoration:none}.main-area{flex:1 1;margin-left:var(--sidebar-width);display:flex;flex-direction:column}.topbar{height:var(--topbar-height);background:var(--color-surface);border-bottom:1px solid var(--color-border);justify-content:flex-end;padding:0 1.5rem;position:-webkit-sticky;position:sticky;top:0;z-index:10}.topbar,.topbar-user{display:flex;align-items:center}.topbar-user{gap:.75rem;font-size:.875rem;color:var(--color-text-secondary)}.topbar-user form button{background:none;border:1px solid var(--color-border);padding:.25rem .75rem;border-radius:4px;font-size:.8125rem;color:var(--color-text-secondary);transition:all .15s}.topbar-user form button:hover{border-color:var(--color-danger);color:var(--color-danger)}.page-content{flex:1 1;padding:2rem 1.5rem;max-width:960px}.page-title{font-size:1.5rem;font-weight:700;margin-bottom:1.5rem}.card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:8px;padding:1.25rem;margin-bottom:1rem}.card h3{font-size:1rem;font-weight:600;margin-bottom:.75rem}.btn{display:inline-flex;align-items:center;justify-content:center;padding:.5rem 1rem;border-radius:6px;font-size:.875rem;font-weight:500;border:none;transition:all .15s}.btn-primary{background:var(--color-primary);color:white}.btn-primary:hover{background:var(--color-primary-hover)}.btn-danger{background:var(--color-danger);color:white}.btn-danger:hover{opacity:.9}.btn-outline{background:transparent;border:1px solid var(--color-border);color:var(--color-text-secondary)}.btn-outline:hover{border-color:var(--color-text);color:var(--color-text)}.form-group{margin-bottom:1rem}.form-group label{display:block;font-size:.8125rem;font-weight:500;color:var(--color-text-secondary);margin-bottom:.25rem}.form-group input,.form-group textarea{width:100%;padding:.5rem .75rem;border:1px solid var(--color-border);border-radius:6px;font-size:.875rem;font-family:inherit;outline:none;transition:border-color .15s}.form-group input:focus,.form-group textarea:focus{border-color:var(--color-accent)}.table{width:100%;border-collapse:collapse}.table td,.table th{text-align:left;padding:.625rem .75rem;border-bottom:1px solid var(--color-border);font-size:.875rem}.table th{font-weight:600;color:var(--color-text-secondary);font-size:.8125rem}.quick-links{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));grid-gap:.75rem;gap:.75rem;margin-bottom:1.5rem}.quick-link{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:8px;font-size:.875rem;color:var(--color-text);text-decoration:none;transition:border-color .15s}.quick-link:hover{border-color:var(--color-accent);text-decoration:none}.placeholder-card{text-align:center;padding:3rem 1.5rem;color:var(--color-text-secondary)}.placeholder-card p{font-size:.875rem}.bookmark-item{display:flex;align-items:flex-start;gap:1rem;padding:.75rem 0;border-bottom:1px solid var(--color-border)}.bookmark-item:last-child{border-bottom:none}.bookmark-thumb{width:64px;height:64px;background:var(--color-bg);border-radius:6px;flex-shrink:0;overflow:hidden}.bookmark-thumb img{width:100%;height:100%;object-fit:cover}.bookmark-info{flex:1 1}.bookmark-info h4{font-size:.875rem;font-weight:600;margin-bottom:.125rem}.bookmark-info .type-badge{font-size:.75rem;color:var(--color-text-secondary)}.bookmark-info .note{font-size:.8125rem;color:var(--color-text-secondary);margin-top:.25rem}.toggle-switch{position:relative;display:inline-block;width:40px;height:22px}.toggle-switch input{opacity:0;width:0;height:0}.toggle-slider{position:absolute;inset:0;background:var(--color-border);border-radius:11px;cursor:pointer;transition:background .2s}.toggle-slider:before{content:"";position:absolute;width:16px;height:16px;left:3px;bottom:3px;background:white;border-radius:50%;transition:transform .2s}.toggle-switch input:checked+.toggle-slider{background:var(--color-accent)}.toggle-switch input:checked+.toggle-slider:before{transform:translateX(18px)}.pref-row{display:flex;align-items:center;justify-content:space-between;padding:.75rem 0;border-bottom:1px solid var(--color-border)}.pref-row:last-child{border-bottom:none}.pref-label{font-size:.875rem}.login-page{display:flex;align-items:center;justify-content:center;min-height:100vh;background:var(--color-bg)}.login-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:12px;padding:2.5rem;text-align:center;max-width:400px;width:100%}.login-card h1{font-size:1.5rem;margin-bottom:.5rem}.login-card p{color:var(--color-text-secondary);font-size:.875rem;margin-bottom:1.5rem}.status-badge{display:inline-block;padding:.125rem .5rem;border-radius:9999px;font-size:.75rem;font-weight:500}.status-active{background:#dcfce7;color:var(--color-success)}.status-pending{background:#fef9c3;color:#ca8a04}.status-cancelled{background:#fee2e2;color:var(--color-danger)}.pagination{display:flex;gap:.5rem;margin-top:1.5rem;align-items:center;justify-content:center}