/* TS Connect - common stylesheet */
:root{
  --navy:#1E2761;
  --navy-dark:#141b4d;
  --ice:#CADCFC;
  --ice-soft:#EEF3FD;
  --white:#FFFFFF;
  --text:#2A2E3A;
  --muted:#6B7280;
  --border:#D8DEE9;
  --danger:#C0392B;
  --gray-row:#EDEFF2;
  --shadow: 0 2px 8px rgba(30,39,97,0.08);
}
*{box-sizing:border-box;}
html,body{margin:0;padding:0;}
body{
  font-family:"Hiragino Kaku Gothic ProN","Meiryo","Segoe UI",Arial,sans-serif;
  color:var(--text);
  background:var(--ice-soft);
  font-size:15px;
  line-height:1.6;
}
a{color:var(--navy);text-decoration:none;}
a:hover{text-decoration:underline;}

/* ------- Header / Global navigation ------- */
.app-header{
  background:var(--navy);
  color:var(--white);
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:14px 28px;
}
.app-header .brand{display:flex;align-items:center;gap:12px;}
.app-header .brand .logo{
  width:38px;height:38px;border-radius:8px;background:var(--ice);color:var(--navy);
  display:flex;align-items:center;justify-content:center;font-weight:700;font-size:15px;
}
.app-header .brand .title{font-size:18px;font-weight:700;letter-spacing:.02em;}
.app-header .brand .subtitle{font-size:12px;color:var(--ice);opacity:.85;margin-left:6px;}
.account-menu{position:relative;}
.account-menu > button{
  background:transparent;border:1px solid rgba(255,255,255,.35);color:var(--white);
  border-radius:20px;padding:8px 16px;font-size:14px;cursor:pointer;display:flex;align-items:center;gap:8px;
}
.account-menu > button:hover{background:rgba(255,255,255,.12);}
.account-menu .menu{
  display:none;position:absolute;right:0;top:calc(100% + 6px);background:var(--white);color:var(--text);
  border-radius:8px;box-shadow:var(--shadow);min-width:180px;overflow:hidden;border:1px solid var(--border);z-index:50;
}
.account-menu.open .menu{display:block;}
.account-menu .menu a{display:block;padding:12px 16px;color:var(--text);font-size:14px;}
.account-menu .menu a:hover{background:var(--ice-soft);text-decoration:none;}
.account-menu .menu a + a{border-top:1px solid var(--border);}

.global-nav{background:var(--navy-dark);display:flex;gap:4px;padding:0 28px;}
.global-nav a{color:var(--ice);padding:13px 22px;font-size:14px;font-weight:600;border-bottom:3px solid transparent;}
.global-nav a:hover{text-decoration:none;color:var(--white);}
.global-nav a.active{color:var(--white);border-bottom-color:var(--ice);}

/* ------- Page layout ------- */
.page{max-width:1180px;margin:0 auto;padding:32px 28px 64px;}
.page-title{font-size:22px;font-weight:700;color:var(--navy);margin:0 0 24px;}
.card{background:var(--white);border-radius:12px;border:1px solid var(--border);box-shadow:var(--shadow);padding:32px;}

/* ------- Forms ------- */
.form-grid{display:flex;flex-direction:column;gap:22px;max-width:520px;}
.form-row label{display:block;font-size:13px;font-weight:700;color:var(--navy);margin-bottom:8px;}
.form-row .hint{font-size:12px;color:var(--muted);margin-top:6px;}
input[type=text],input[type=email],input[type=password],input[type=search],select,textarea{
  width:100%;padding:11px 14px;border:1px solid var(--border);border-radius:8px;
  font-size:15px;background:var(--white);color:var(--text);
}
input:focus,select:focus,textarea:focus{
  outline:none;border-color:var(--navy);box-shadow:0 0 0 3px rgba(30,39,97,.12);
}
.static-value{padding:11px 14px;background:var(--ice-soft);border-radius:8px;font-size:15px;color:var(--text);}

/* ------- Buttons ------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding:11px 28px;border-radius:24px;font-size:14px;font-weight:700;
  border:1px solid transparent;cursor:pointer;transition:all .15s ease;
}
.btn-primary{background:var(--navy);color:var(--white);}
.btn-primary:hover{background:var(--navy-dark);text-decoration:none;}
.btn-secondary{background:var(--white);color:var(--navy);border-color:var(--navy);}
.btn-secondary:hover{background:var(--ice-soft);text-decoration:none;}
.btn-link{background:transparent;color:var(--navy);border:none;text-decoration:underline;padding:8px 4px;}
.btn-row{display:flex;gap:14px;margin-top:8px;}
.btn:disabled{opacity:.5;cursor:not-allowed;}

/* ------- Alerts ------- */
.alert{padding:14px 18px;border-radius:8px;font-size:14px;margin-bottom:20px;}
.alert-error{background:#FCEBEA;color:var(--danger);border:1px solid #F2C6C2;}
.alert-success{background:#E7F4EC;color:#1F7A45;border:1px solid #BFE3CC;}
.alert-info{background:var(--ice-soft);color:var(--navy);border:1px solid var(--ice);}

/* ------- Auth pages (login / password) ------- */
.auth-wrap{
  min-height:100vh;display:flex;align-items:center;justify-content:center;
  background:linear-gradient(135deg,var(--navy) 0%,#3B4694 100%);padding:24px;
}
.auth-card{
  background:var(--white);border-radius:16px;box-shadow:0 12px 40px rgba(20,27,77,.35);
  width:100%;max-width:440px;padding:44px 40px;
}
.auth-logo{display:flex;align-items:center;gap:12px;margin-bottom:6px;}
.auth-logo .logo{
  width:44px;height:44px;border-radius:10px;background:var(--navy);color:var(--ice);
  display:flex;align-items:center;justify-content:center;font-weight:700;font-size:17px;
}
.auth-logo .name{font-size:20px;font-weight:700;color:var(--navy);}
.auth-logo .tagline{font-size:12px;color:var(--muted);margin-top:2px;}
.auth-card h1{font-size:18px;margin:28px 0 22px;color:var(--text);}
.auth-card .form-grid{max-width:none;gap:18px;}
.auth-card .btn-primary{width:100%;padding:13px;font-size:15px;}
.auth-foot{margin-top:20px;text-align:center;font-size:13px;}
.auth-back{margin-top:28px;text-align:center;font-size:13px;}

/* ------- Top page ------- */
.top-empty{
  background:var(--white);border:1px dashed var(--border);border-radius:12px;
  padding:80px 24px;text-align:center;color:var(--muted);font-size:14px;
}

/* ------- User list ------- */
.list-toolbar{display:flex;justify-content:space-between;align-items:flex-end;flex-wrap:wrap;gap:16px;margin-bottom:20px;}
.search-box{display:flex;gap:10px;align-items:center;}
.search-box input{width:280px;}
.result-meta{font-size:13px;color:var(--muted);margin-bottom:12px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px;}
.toolbar-actions{display:flex;gap:10px;}

table.user-table{width:100%;border-collapse:collapse;font-size:14px;}
table.user-table th{background:var(--navy);color:var(--white);text-align:left;padding:12px 16px;font-weight:600;font-size:13px;}
table.user-table th:first-child{border-radius:8px 0 0 0;}
table.user-table th:last-child{border-radius:0 8px 0 0;}
table.user-table td{padding:12px 16px;border-bottom:1px solid var(--border);background:var(--white);}
table.user-table tr.inactive td{background:var(--gray-row);color:var(--muted);}
table.user-table td.col-id{width:70px;color:var(--muted);}
table.user-table td.col-edit{width:90px;text-align:center;}
table.user-table td.col-status,table.user-table th.col-status{width:120px;white-space:nowrap;}
.badge{display:inline-block;padding:3px 12px;border-radius:12px;font-size:12px;font-weight:700;}
.badge-active{background:#E7F4EC;color:#1F7A45;}
.badge-inactive{background:#E6E8EC;color:var(--muted);}

.pager{display:flex;align-items:center;gap:14px;margin-top:20px;justify-content:center;font-size:14px;}
.pager .btn-secondary{padding:8px 20px;}
.page-size-row{display:flex;align-items:center;gap:10px;margin-top:18px;font-size:13px;color:var(--muted);justify-content:flex-end;}
.page-size-row select{width:80px;display:inline-block;}

/* ------- Misc ------- */
.field-row-2{display:grid;grid-template-columns:1fr 1fr;gap:18px;}
@media (max-width:640px){
  .field-row-2{grid-template-columns:1fr;}
  .app-header,.global-nav,.page{padding-left:16px;padding-right:16px;}
}
