
/* AMOM Program Pages — front styles (academic / clean, Chinese-inspired accents) */
@import url('https://fonts.googleapis.com/css2?family=Merriweather:wght@300;400;700;900&family=Source+Sans+3:wght@400;600;700&display=swap');

.amom-program{
  --bg:#fbf7ef;
  --bg2:#f6efe3;
  --ink:#1b2430;
  --muted:#4c5a6a;
  --gold:#b08d57;
  --line: rgba(27,36,48,.14);
  --card:#ffffffcc;
  --card2:#ffffff;
  --shadow: 0 14px 34px rgba(27,36,48,.10);
  --radius: 18px;
  --container: 1120px;

  --accent: attr(data-accent color, #1f6b4c);
  font-family: "Merriweather", Georgia, "Times New Roman", serif;
  color: var(--ink);
  line-height: 1.6;
  position: relative;
  background:
    radial-gradient(900px 520px at 12% -10%, color-mix(in srgb, var(--accent) 16%, transparent), transparent 60%),
    radial-gradient(900px 520px at 90% 0%, rgba(176,141,87,.16), transparent 60%),
    linear-gradient(180deg, var(--bg), var(--bg2));
}

.amom-wrap{max-width:var(--container); margin:0 auto; padding:0 18px;}
.amom-small{font-family:"Source Sans 3",sans-serif; font-size:12px; color:var(--muted);}

.amom-pattern{
  position:absolute; inset:0; pointer-events:none; z-index:0;
  background-image:
    radial-gradient(circle at 20% 20%, color-mix(in srgb, var(--accent) 6%, transparent) 0 2px, transparent 3px),
    radial-gradient(circle at 80% 30%, rgba(176,141,87,.06) 0 2px, transparent 3px),
    radial-gradient(circle at 40% 80%, color-mix(in srgb, var(--accent) 5%, transparent) 0 2px, transparent 3px);
  background-size: 220px 220px;
  opacity:.9;
}

.amom-topbar{
  position: sticky; top:0; z-index:50;
  background: rgba(251,247,239,.82);
  backdrop-filter: blur(10px);
  border-bottom: 1px solid var(--line);
}
.amom-row{
  display:flex; align-items:center; justify-content:space-between;
  gap:12px; flex-wrap:wrap; padding:12px 0;
}
.amom-brand{display:flex; align-items:center; gap:12px; font-weight:900; letter-spacing:.2px;}
.amom-brand-title{font-weight:900;}
.amom-seal{
  width:38px; height:38px; border-radius:999px;
  border:2px solid color-mix(in srgb, var(--accent) 45%, transparent);
  display:grid; place-items:center;
  background: linear-gradient(180deg, color-mix(in srgb, var(--accent) 10%, transparent), rgba(176,141,87,.10));
}
.amom-seal span{font-family:"Source Sans 3",sans-serif; font-weight:800; font-size:12px; color: var(--accent);}

.amom-pill{
  font-family:"Source Sans 3",sans-serif;
  font-size:12px; font-weight:800;
  padding:5px 10px; border-radius:999px;
  border:1px solid color-mix(in srgb, var(--accent) 20%, transparent);
  background: color-mix(in srgb, var(--accent) 6%, transparent);
  color: var(--accent);
  white-space:nowrap;
}

.amom-nav{display:flex; gap:8px; flex-wrap:wrap; font-family:"Source Sans 3",sans-serif;}
.amom-nav a{
  text-decoration:none; color:var(--muted); font-weight:650; font-size:14px;
  padding:7px 10px; border-radius:999px; border:1px solid transparent;
}
.amom-nav a:hover{
  color: var(--accent);
  border-color: color-mix(in srgb, var(--accent) 18%, transparent);
  background: color-mix(in srgb, var(--accent) 5%, transparent);
}

.amom-btn{
  font-family:"Source Sans 3",sans-serif;
  border:0; cursor:pointer; text-decoration:none;
  padding:10px 14px; border-radius:999px; font-weight:800;
  display:inline-flex; align-items:center; gap:8px; white-space:nowrap;
}
.amom-btn-gold{
  background: linear-gradient(90deg, var(--gold), #c8a26c);
  color:#1b2430;
  box-shadow: 0 12px 24px rgba(176,141,87,.18);
}
.amom-btn-outline{
  background: transparent;
  border:1px solid color-mix(in srgb, var(--accent) 28%, transparent);
  color: var(--accent);
}

.amom-main{position:relative; z-index:1;}
.amom-hero{padding:26px 0 14px;}
.amom-hero-grid{display:grid; grid-template-columns: 1.12fr .88fr; gap:16px; align-items:stretch;}
.amom-card{
  background: linear-gradient(180deg, var(--card), var(--card2));
  border:1px solid var(--line);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  overflow:hidden;
}
.amom-pad{padding:18px;}
.amom-h1{margin:0 0 10px; font-size:34px; line-height:1.15;}
.amom-sub{margin:0 0 14px; color:var(--muted); font-family:"Source Sans 3",sans-serif; font-size:16px;}

.amom-titleline{display:flex; align-items:center; gap:10px; margin-bottom:10px;}
.amom-bar{height:2px; flex:1; background: linear-gradient(90deg, transparent, color-mix(in srgb, var(--accent) 55%, transparent), rgba(176,141,87,.55), transparent);}
.amom-knot{
  width:12px; height:12px; border-radius:3px;
  transform: rotate(45deg);
  background: linear-gradient(180deg, color-mix(in srgb, var(--accent) 70%, transparent), rgba(176,141,87,.60));
  border:1px solid rgba(27,36,48,.12);
}

.amom-actions{display:flex; gap:10px; flex-wrap:wrap;}

.amom-kpis{
  display:grid; grid-template-columns:repeat(3,1fr);
  gap:10px; margin-top:12px;
  font-family:"Source Sans 3",sans-serif;
}
.amom-kpi{
  padding:12px; border-radius:14px;
  border:1px solid rgba(27,36,48,.12);
  background: rgba(255,255,255,.72);
}
.amom-kpi b{display:block; font-size:15px; color: var(--accent);}
.amom-kpi span{display:block; font-size:12px; color: var(--muted); margin-top:2px;}

.amom-hero-img{min-height:290px;}
.amom-hero-img img{width:100%; height:100%; object-fit:cover; display:block;}
.amom-hero-placeholder{padding:18px; font-family:"Source Sans 3",sans-serif; color:var(--muted);}

.amom-note{
  margin-top:12px;
  padding:12px;
  border-radius:14px;
  border:1px dashed rgba(27,36,48,.20);
  background: rgba(255,255,255,.68);
  color: var(--muted);
  font-family:"Source Sans 3",sans-serif;
  font-size:13px;
}

.amom-section{padding:12px 0 18px;}
.amom-h2{margin:0 0 10px; font-size:22px;}
.amom-grid-2{display:grid; grid-template-columns:1fr 1fr; gap:14px;}

.amom-badge{
  display:inline-flex; align-items:center; gap:8px;
  font-family:"Source Sans 3",sans-serif;
  font-size:12px; font-weight:800;
  padding:5px 10px; border-radius:999px;
  color: var(--accent);
  border:1px solid color-mix(in srgb, var(--accent) 18%, transparent);
  background: color-mix(in srgb, var(--accent) 5%, transparent);
}

.amom-list{margin:10px 0 0; padding-left:18px;}
.amom-list li{margin:6px 0; color: var(--muted); font-family:"Source Sans 3",sans-serif;}

.amom-table{
  width:100%;
  border-collapse:separate;
  border-spacing:0;
  border:1px solid rgba(27,36,48,.12);
  border-radius:14px;
  overflow:hidden;
  background:#fff;
  font-family:"Source Sans 3",sans-serif;
  margin-top:10px;
}
.amom-table th, .amom-table td{
  padding:10px 12px;
  border-bottom:1px solid rgba(27,36,48,.10);
  vertical-align:top;
  text-align:left;
  font-size:14px;
}
.amom-table th{
  font-weight:900;
  color: var(--accent);
  background: color-mix(in srgb, var(--accent) 4%, transparent);
}
.amom-table tr:last-child td{border-bottom:0;}
.amom-part{margin-bottom:14px;}

.amom-form{display:grid; gap:10px; margin-top:10px; font-family:"Source Sans 3",sans-serif;}
.amom-field{display:grid; gap:6px;}
.amom-field label{font-size:13px; color:var(--muted); font-weight:650;}
.amom-field input, .amom-field select, .amom-field textarea{
  padding:10px 12px;
  border-radius:12px;
  border:1px solid rgba(27,36,48,.18);
  background:#fff;
  font-size:14px;
  outline:none;
}
.amom-field input:focus, .amom-field select:focus, .amom-field textarea:focus{
  border-color: color-mix(in srgb, var(--accent) 45%, transparent);
  box-shadow: 0 0 0 4px color-mix(in srgb, var(--accent) 10%, transparent);
}
.amom-row2{display:grid; grid-template-columns:1fr 1fr; gap:10px;}
.amom-embed{font-family:"Source Sans 3",sans-serif;}
.amom-footer{
  border-top: 1px solid rgba(27,36,48,.12);
  background: rgba(255,255,255,.55);
  padding: 14px 0 18px;
  color: var(--muted);
  font-family:"Source Sans 3",sans-serif;
  font-size: 13px;
}

/* Simple JS hooks */
.amom-program [data-role="startDates"]{margin-top:10px; font-family:"Source Sans 3",sans-serif; color:var(--muted);}
.amom-program [data-role="seatStatus"]{margin-top:10px;}

@media (max-width: 920px){
  .amom-hero-grid{grid-template-columns:1fr;}
  .amom-kpis{grid-template-columns:1fr;}
  .amom-grid-2{grid-template-columns:1fr;}
  .amom-row2{grid-template-columns:1fr;}
  .amom-h1{font-size:28px;}
}

/* JS: set accent variable */
.amom-program{ --accent: #1f6b4c; }
.amom-program[data-accent]{ --accent: attr(data-accent); }
