*,:before,:after{box-sizing:border-box;margin:0;padding:0}body{color:#333;background:#fff;min-height:100vh;font-family:-apple-system,BlinkMacSystemFont,Hiragino Sans,Hiragino Kaku Gothic ProN,Meiryo,sans-serif;line-height:1.6}.login-page{background:#fafafa;justify-content:center;align-items:center;min-height:100vh;display:flex}.login-container{width:100%;max-width:360px;padding:0 16px}.login-header{text-align:center;margin-bottom:24px}.login-header h1{color:#222;font-size:20px;font-weight:700}.login-form{background:#fff;border:1px solid #eee;border-radius:8px;padding:28px 24px;box-shadow:0 2px 8px #00000014}.error-message{color:#c00;background:#fee;border:1px solid #fcc;border-radius:6px;margin-bottom:16px;padding:10px 14px;font-size:13px}.form-group{margin-bottom:16px}.form-group label{color:#555;margin-bottom:6px;font-size:13px;font-weight:600;display:block}.form-group input,.form-group select,.form-group textarea{color:#333;border:1px solid #ddd;border-radius:6px;width:100%;padding:10px 12px;font-size:15px;transition:border-color .15s}.form-group input:focus,.form-group select:focus{border-color:#888;outline:none}.btn-primary{color:#fff;cursor:pointer;background:#222;border:none;border-radius:6px;width:100%;padding:12px;font-size:15px;font-weight:600;transition:background .15s}.btn-primary:hover{background:#444}.btn-primary:disabled{cursor:not-allowed;background:#999}.btn-secondary{color:#333;cursor:pointer;background:#f5f5f5;border:1px solid #ddd;border-radius:6px;padding:10px 20px;font-size:14px}.btn-secondary:hover{background:#eee}.btn-text{color:#fffc;cursor:pointer;background:0 0;border:none;border-radius:4px;padding:4px 8px;font-size:13px;text-decoration:none;transition:background .15s}.btn-text:hover{color:#fff;background:#ffffff1a}.portal-header{color:#fff;background:#222;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:8px;padding:12px 20px;display:flex}.portal-title{font-size:16px;font-weight:700}.portal-user{flex-wrap:wrap;align-items:center;gap:4px;display:flex}.user-name{opacity:.8;margin-right:8px;font-size:13px}.portal-main{max-width:960px;margin:0 auto;padding:24px 20px}.app-grid{grid-template-columns:repeat(2,1fr);gap:12px;display:grid}@media (min-width:600px){.app-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px}}.app-card{text-align:center;color:#333;background:#f5f5f5;border-radius:10px;padding:24px 12px;text-decoration:none;transition:box-shadow .15s,transform .15s;display:block}.app-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.app-icon{border-radius:16px;justify-content:center;align-items:center;width:80px;height:80px;margin:0 auto 12px;font-size:32px;display:flex}.app-name{font-size:13px;font-weight:600;line-height:1.4}.app-desc{color:#999;margin-top:3px;font-size:11px}.portal-page{color:#2d3748;background:linear-gradient(#ffffffb3,#ffffffb3),url(/portal-bg.webp) 50%/cover no-repeat fixed,linear-gradient(#f7f9fc 0%,#eef1f6 100%);min-height:100vh}.portal-page .portal-header{-webkit-backdrop-filter:blur(20px)saturate(180%);color:#2d3748;background:#ffffff8c;border-bottom:1px solid #fff9;box-shadow:inset 0 1px #ffffffe6}.portal-page .portal-title{color:#2d3748;letter-spacing:.02em}.portal-page .user-name{color:#4a5568;opacity:1}.portal-page .btn-text{color:#4a5568;border-radius:999px}.portal-page .btn-text:hover{color:#1a202c;background:#ffffffbf}.portal-page .app-card{-webkit-backdrop-filter:blur(24px)saturate(180%);color:#2d3748;background:#ffffff73;border:1.5px solid #ffffffb3;border-radius:22px;transition:background .2s,box-shadow .2s,transform .2s,border-color .2s;box-shadow:inset 0 1px #fffffff2,inset 0 -1px #ffffff40,0 8px 24px #7882a026}.portal-page .app-card:hover{background:#ffffffb3;border-color:#fffffff2;transform:translateY(-2px);box-shadow:inset 0 1px #fff,inset 0 -1px #ffffff4d,0 12px 32px #7882a038}.portal-page .app-icon{border-radius:18px;box-shadow:inset 0 1px #fffffff2,0 4px 12px #7882a02e}.portal-page .app-name{color:#2d3748;font-weight:600}.portal-page .app-desc{color:#718096}.modal{z-index:1000;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-overlay{background:#0006;position:absolute;inset:0}.modal-content{background:#fff;border-radius:10px;width:90%;max-width:400px;max-height:90vh;padding:28px 24px;position:relative;overflow-y:auto;box-shadow:0 8px 30px #00000026}.modal-content h2{color:#222;margin-bottom:20px;font-size:18px}.modal-actions{justify-content:flex-end;gap:10px;margin-top:20px;display:flex}.modal-actions .btn-primary{width:auto;padding:10px 24px}.form-message{border-radius:6px;margin-top:12px;padding:10px 14px;font-size:13px}.form-message.error{color:#c00;background:#fee;border:1px solid #fcc}.form-message.success{color:#060;background:#efe;border:1px solid #cfc}.admin-header{color:#fff;background:#222;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:8px;padding:12px 20px;display:flex}.admin-nav{gap:4px;display:flex}.admin-nav a{color:#ffffffb3;border-radius:4px;padding:6px 12px;font-size:13px;text-decoration:none;transition:background .15s}.admin-nav a:hover,.admin-nav a.active{color:#fff;background:#ffffff26}.admin-main{max-width:1200px;margin:0 auto;padding:24px 20px}.admin-main h2{color:#222;margin-bottom:20px;font-size:18px}.admin-toolbar{justify-content:flex-end;margin-bottom:16px;display:flex}.btn-add{color:#fff;cursor:pointer;background:#222;border:none;border-radius:6px;padding:8px 16px;font-size:13px;font-weight:600}.btn-add:hover{background:#444}.admin-table{border-collapse:collapse;width:100%;min-width:900px;font-size:13px}.admin-table th,.admin-table td{text-align:left;white-space:nowrap;border-bottom:1px solid #eee;padding:8px 10px}.admin-table th{color:#888;background:#fafafa;font-size:11px;font-weight:600}.admin-table tr:hover td{background:#f9f9f9}.admin-table td.col-actions{white-space:nowrap}.btn-edit,.btn-delete{cursor:pointer;border:none;border-radius:4px;margin-bottom:4px;margin-right:4px;padding:4px 10px;font-size:12px}.btn-edit{color:#333;background:#eee}.btn-delete{color:#c00;background:#fee}.btn-edit:hover{background:#ddd}.btn-delete:hover{background:#fdd}.badge{white-space:nowrap;border-radius:10px;padding:2px 8px;font-size:11px;font-weight:600;display:inline-block}.badge-active{color:#060;background:#efe}.badge-inactive{color:#999;background:#f5f5f5}.badge-admin{color:#06c;background:#e8f4fd}.badge-deputy{color:#c62828;background:#fce4ec}.badge-manager{color:#06c;background:#e8f4fd}.badge-leader{color:#e65100;background:#fff3e0}.badge-member{color:#666;background:#f5f5f5}.badge-outsource{color:#1a73e8;background:#e8f0fe}.pw-input-wrap{align-items:center;display:flex;position:relative}.pw-input-wrap input{flex:1;padding-right:40px}.pw-toggle{cursor:pointer;opacity:.5;background:0 0;border:none;padding:2px 4px;font-size:18px;line-height:1;position:absolute;right:8px}.pw-toggle:hover{opacity:1}.user-card-list{display:none}.user-card{background:#fff;border:1px solid #eee;border-radius:8px;margin-bottom:10px;padding:14px 16px}.user-card-header{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.user-card-name{color:#222;font-size:14px;font-weight:600}.user-card-self{color:#888;margin-left:4px;font-size:11px}.user-card-meta{color:#666;flex-wrap:wrap;gap:6px 12px;margin-bottom:8px;font-size:12px;display:flex}.user-card-meta span{align-items:center;gap:3px;display:inline-flex}.user-card-meta .meta-label{color:#999;font-size:11px}.user-card-actions{border-top:1px solid #f0f0f0;gap:10px;padding-top:8px;display:flex}.user-card-actions button{flex:1;padding:8px 0;font-size:12px}@media (max-width:767px){.admin-header{padding:10px 16px}.admin-main{padding:16px}.admin-main h2{margin-bottom:14px;font-size:16px}.admin-table-wrapper{display:none}.user-card-list{display:block}.modal-content{width:95%;padding:20px 16px}}@media (min-width:768px){.admin-table-wrapper{-webkit-overflow-scrolling:touch;overflow-x:auto}.user-card-list{display:none}}
