*,*:before,*:after{box-sizing:border-box}body{margin:0}.offline-banner{background:#b85555;color:#fff;text-align:center;padding:6px;font-size:12px;letter-spacing:.04em;position:sticky;top:0;z-index:1000}:root{--bg: #F7F3EE;--surface: #FFFFFF;--border: #E5DDD4;--border-light: #EDE8E1;--text-primary: #2A2420;--text-secondary: #7B6F67;--text-muted: #B8AFA8;--accent: #9E7B5A;--accent-light: #F5EDE3;--accent-hover: #82634A;--gold: #C4A46B;--gold-light: #FAF5EA;--gold-border: #E5D4AC;--danger: #B85555;--danger-light: #FDF2F2;--danger-border: #E8BABA;--sage: #7A9E8A;--sage-light: #EEF6F1;--shadow-sm: 0 1px 4px rgba(42, 36, 32, .06);--shadow-md: 0 4px 20px rgba(42, 36, 32, .09);--shadow-lg: 0 12px 48px rgba(42, 36, 32, .13);--radius-sm: 8px;--radius-md: 12px;--radius-lg: 20px;--radius-full: 999px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:Hiragino Kaku Gothic ProN,Hiragino Sans,Yu Gothic UI,Meiryo UI,sans-serif;font-size:14px;color:var(--text-primary);background:var(--bg);line-height:1.6;-webkit-font-smoothing:antialiased}.loading-screen{display:flex;align-items:center;justify-content:center;height:100vh;color:var(--text-muted);letter-spacing:.08em;font-size:13px}.login-container{display:flex;align-items:center;justify-content:center;min-height:100vh;background:radial-gradient(ellipse at 20% 50%,rgba(196,164,107,.12) 0%,transparent 60%),radial-gradient(ellipse at 80% 20%,rgba(158,123,90,.1) 0%,transparent 50%),var(--bg)}.login-card{background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);padding:52px 44px 44px;width:100%;max-width:400px;border:1px solid var(--border-light)}.login-title{font-size:17px;font-weight:600;color:var(--text-primary);margin-bottom:32px;text-align:center;letter-spacing:.12em}.login-title:after{content:"";display:block;width:32px;height:2px;background:linear-gradient(90deg,var(--gold),var(--accent));margin:12px auto 0;border-radius:var(--radius-full)}.field{margin-bottom:18px}.field-short{max-width:160px}.field-full{grid-column:1 / -1}.label{display:block;font-size:11px;font-weight:600;color:var(--text-secondary);margin-bottom:6px;letter-spacing:.1em;text-transform:uppercase}.input{width:100%;padding:10px 14px;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:14px;font-family:inherit;color:var(--text-primary);background:var(--surface);transition:border-color .2s,box-shadow .2s}.input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #9e7b5a1f}.input:disabled{background:var(--bg);color:var(--text-muted)}.textarea{resize:vertical;min-height:80px}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:0 16px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:9px 20px;border:none;border-radius:var(--radius-sm);font-size:13px;font-family:inherit;font-weight:600;letter-spacing:.04em;cursor:pointer;transition:background .18s,box-shadow .18s,opacity .18s;white-space:nowrap}.btn:disabled{opacity:.45;cursor:not-allowed}.btn-primary{background:linear-gradient(135deg,var(--accent),var(--accent-hover));color:#fff;box-shadow:0 2px 8px #9e7b5a47}.btn-primary:hover:not(:disabled){background:linear-gradient(135deg,var(--accent-hover),#6B503C);box-shadow:0 4px 16px #9e7b5a5c}.btn-secondary{background:var(--surface);color:var(--text-secondary);border:1px solid var(--border)}.btn-secondary:hover:not(:disabled){background:var(--bg);border-color:var(--accent);color:var(--accent)}.btn-danger{background:var(--danger-light);color:var(--danger);border:1px solid var(--danger-border)}.btn-danger:hover:not(:disabled){background:#fae5e5}.btn-password{background:var(--gold-light);color:#8a6a35;border:1px solid var(--gold-border)}.btn-password:hover:not(:disabled){background:#f5edd4}.btn-full{width:100%;margin-top:8px}.btn-sm{padding:5px 12px;font-size:12px}.header{display:flex;align-items:center;justify-content:space-between;padding:0 32px;height:60px;background:var(--surface);border-bottom:1px solid var(--border-light);position:sticky;top:0;z-index:10;box-shadow:var(--shadow-sm)}.header-title{font-size:15px;font-weight:700;color:var(--text-primary);letter-spacing:.1em}.header-title:before{content:"";display:inline-block;width:3px;height:14px;background:linear-gradient(180deg,var(--gold),var(--accent));border-radius:var(--radius-full);margin-right:10px;vertical-align:-2px}.header-right{display:flex;align-items:center;gap:16px}.user-info{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--text-secondary);letter-spacing:.02em}.role-badge{padding:3px 10px;border-radius:var(--radius-full);font-size:11px;font-weight:600;letter-spacing:.06em}.role-admin{background:var(--gold-light);color:#7a5c2a;border:1px solid var(--gold-border)}.role-user{background:var(--sage-light);color:#3d6e52;border:1px solid #C2DDD0}.page{min-height:100vh;display:flex;flex-direction:column}.main{padding:32px;flex:1;max-width:1200px;margin:0 auto;width:100%}.toolbar{margin-bottom:20px}.table-wrapper{overflow-x:auto;border-radius:var(--radius-md);box-shadow:var(--shadow-md);border:1px solid var(--border-light)}.table{width:100%;border-collapse:collapse;background:var(--surface)}.table th{padding:14px 20px;text-align:left;font-size:11px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.1em;background:#fdfaf7;border-bottom:1px solid var(--border);white-space:nowrap}.table td{padding:14px 20px;border-bottom:1px solid var(--border-light);vertical-align:middle;font-size:14px}.table tbody tr:last-child td{border-bottom:none}.table tbody tr{transition:background .15s}.table tbody tr:hover{background:#fdfaf7}.monospace{font-family:SF Mono,Fira Code,Consolas,monospace;font-size:13px;color:var(--text-secondary)}.memo-cell{max-width:200px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--text-muted);font-size:13px}.action-buttons{display:flex;gap:6px}.modal-backdrop{position:fixed;inset:0;background:#2a24205c;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);display:flex;align-items:center;justify-content:center;z-index:100;padding:16px;animation:fadeIn .15s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal{background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:100%;max-width:460px;max-height:90vh;overflow-y:auto;border:1px solid var(--border-light);animation:slideUp .2s ease}@keyframes slideUp{0%{transform:translateY(12px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-large{max-width:660px}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:24px 28px 0}.modal-title{font-size:15px;font-weight:700;color:var(--text-primary);letter-spacing:.06em}.modal-close{background:none;border:none;font-size:18px;color:var(--text-muted);cursor:pointer;line-height:1;padding:4px;width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background .15s,color .15s}.modal-close:hover{background:var(--bg);color:var(--text-secondary)}.modal form{padding:20px 28px}.modal-footer{display:flex;justify-content:flex-end;gap:8px;padding:16px 28px 20px;border-top:1px solid var(--border-light)}.modal-service-name{padding:12px 28px 0;font-weight:600;color:var(--text-primary);font-size:15px;letter-spacing:.04em}.password-display{display:flex;gap:8px;padding:16px 28px}.password-display .input{flex:1;font-family:SF Mono,Fira Code,Consolas,monospace;letter-spacing:.06em}.audit-notice{padding:0 28px 12px;font-size:11px;color:var(--text-muted);letter-spacing:.04em;display:flex;align-items:center;gap:4px}.audit-notice:before{content:"🔒";font-size:10px}.error-msg{color:var(--danger);background:var(--danger-light);border:1px solid var(--danger-border);border-radius:var(--radius-sm);padding:10px 14px;font-size:13px;margin-top:10px;letter-spacing:.02em}.loading-text,.empty-text{color:var(--text-muted);text-align:center;padding:64px 0;letter-spacing:.06em;font-size:13px}
