/* ============================================================
   ivory_court · base.css · 白底版
   主题：IVORY COURT 象牙网球白场
   主色：#15803d / 强调色：#92400e
   ============================================================ */

:root {
  --ks-primary: #15803d;
  --ks-primary-hover: color-mix(in srgb, #15803d 85%, #000);
  --ks-accent: #92400e;
  --ks-accent-hover: color-mix(in srgb, #92400e 85%, #000);
  --ks-cyan: #0ea5e9;
  --ks-danger: #dc2626;
  --ks-success: #16a34a;

  /* 白底基色 —— 5 级灰阶 */
  --ks-bg: #ffffff;
  --ks-bg-2: #fafafa;
  --ks-bg-3: #f4f4f5;
  --ks-bg-soft: #e4e4e7;
  --ks-overlay: rgba(0, 0, 0, .03);

  --ks-border: rgba(0, 0, 0, .08);
  --ks-border-strong: rgba(0, 0, 0, .16);

  --ks-text: #18181b;
  --ks-text-2: #3f3f46;
  --ks-muted: #71717a;

  --ks-shadow-sm: 0 1px 2px rgba(0, 0, 0, .04);
  --ks-shadow: 0 2px 8px rgba(0, 0, 0, .06);
  --ks-shadow-lg: 0 8px 24px rgba(0, 0, 0, .10);

  --ks-radius: 8px;
  --ks-radius-sm: 4px;
  --ks-radius-lg: 14px;
}

* { box-sizing: border-box; }

html, body {
  background: var(--ks-bg);
  color: var(--ks-text);
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", "PingFang SC",
    "Hiragino Sans GB", "Microsoft YaHei", "Helvetica Neue", Helvetica, Arial,
    sans-serif;
  -webkit-font-smoothing: antialiased;
  font-size: 15px;
  line-height: 1.65;
  scroll-behavior: smooth;
}

section[id] { scroll-margin-top: 80px; }

body { background: var(--ks-bg); }

a { color: var(--ks-primary); text-decoration: none; }
a:hover { color: var(--ks-primary-hover); }

img { max-width: 100%; height: auto; display: block; }

::selection { background: var(--ks-primary); color: #fff; }

/* 表格、列表、表单基础样式（白底版） */
table { width: 100%; border-collapse: collapse; }
th, td { padding: 10px 12px; border-bottom: 1px solid var(--ks-border); text-align: left; }
th { background: var(--ks-bg-3); font-weight: 600; }

input, textarea, select {
  background: #fff;
  color: var(--ks-text);
  border: 1px solid var(--ks-border);
  border-radius: var(--ks-radius-sm);
  padding: 8px 10px;
  font: inherit;
}
input:focus, textarea:focus, select:focus { outline: 2px solid var(--ks-primary); outline-offset: 1px; }

button { cursor: pointer; font: inherit; }

/* Bootstrap navbar 白底覆写 */
.navbar { background: #fff !important; border-bottom: 1px solid var(--ks-border); }
.navbar .nav-link, .navbar-brand, .navbar-text { color: var(--ks-text) !important; }
.navbar .nav-link:hover { color: var(--ks-primary) !important; }
.dropdown-menu { background: #fff; border: 1px solid var(--ks-border); }
.dropdown-item { color: var(--ks-text); }
.dropdown-item:hover { background: var(--ks-bg-3); color: var(--ks-primary); }

/* 滚动条 */
::-webkit-scrollbar { width: 8px; height: 8px; }
::-webkit-scrollbar-track { background: var(--ks-bg-2); }
::-webkit-scrollbar-thumb { background: var(--ks-border-strong); border-radius: 4px; }
::-webkit-scrollbar-thumb:hover { background: var(--ks-muted); }
/* =================================================== */
/* MOBILE ENHANCED · 全局 H5 自适应基础规则             */
/* =================================================== */
/* 通用响应式元素 */
img, svg, video, canvas, iframe { max-width: 100%; height: auto; }
table { display: block; overflow-x: auto; -webkit-overflow-scrolling: touch; max-width: 100%; }
table table { display: table; overflow: visible; }
pre, code { overflow-x: auto; white-space: pre-wrap; word-break: break-word; }

/* 触控友好 */
a, button, input[type="button"], input[type="submit"], .btn { -webkit-tap-highlight-color: transparent; }
input, select, textarea { font-size: 16px; }  /* 防止 iOS 自动缩放 */

/* 平板（≤ 992px）*/
@media (max-width: 991.98px) {
  html, body { font-size: 15px; }
  h1 { font-size: 2rem; line-height: 1.2; }
  h2 { font-size: 1.6rem; }
  h3 { font-size: 1.3rem; }
  .container { padding-left: 16px; padding-right: 16px; }
}

/* 手机（≤ 768px）*/
@media (max-width: 768px) {
  html, body { font-size: 16px; line-height: 1.6; }
  body { -webkit-text-size-adjust: 100%; word-break: break-word; overflow-wrap: break-word; }
  h1 { font-size: 1.75rem; line-height: 1.25; }
  h2 { font-size: 1.4rem; line-height: 1.3; }
  h3 { font-size: 1.15rem; }
  h4, h5, h6 { font-size: 1rem; }
  p { font-size: 1rem; line-height: 1.7; }
  /* 通用容器收紧 padding */
  .container, .container-fluid { padding-left: 16px; padding-right: 16px; max-width: 100%; }
  /* 表格横滚 */
  .table-responsive { overflow-x: auto; -webkit-overflow-scrolling: touch; }
  /* 按钮满宽或半宽 */
  .btn { min-height: 44px; padding: 10px 18px; font-size: 15px; }
  .btn-block, .btn-full { display: block; width: 100%; }
  /* 表单 */
  .form-control, .form-select { font-size: 16px; padding: 10px 14px; min-height: 44px; }
  /* 卡片 */
  .card { margin-bottom: 14px; border-radius: 12px; }
  .card-body { padding: 18px 16px; }
  /* 列表组 */
  .list-group-item { padding: 12px 14px; font-size: 15px; }
  /* modal */
  .modal-dialog { margin: 16px; }
  .modal-content { border-radius: 14px; }
}

/* 小手机（≤ 480px）进一步收紧 */
@media (max-width: 480px) {
  html, body { font-size: 15px; }
  h1 { font-size: 1.5rem; }
  h2 { font-size: 1.25rem; }
  .btn { padding: 10px 14px; font-size: 14px; }
}
