/* Shared page shell — used by /admin, /pesan, /asuransi, /karir, /dra placeholder pages */
:root {
  --ink: #0E1B2C;
  --ink-soft: #1E2D45;
  --paper: #F6F1E7;
  --paper-warm: #EFE7D6;
  --gold: #C9A14A;
  --gold-deep: #A8812F;
  --teal: #0E5A5A;
  --line: rgba(14, 27, 44, 0.12);
  --display: 'Bricolage Grotesque', serif;
  --body: 'Plus Jakarta Sans', sans-serif;
  --mono: 'JetBrains Mono', monospace;
}
* { margin: 0; padding: 0; box-sizing: border-box; }
body {
  font-family: var(--body);
  background: var(--paper);
  color: var(--ink);
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
}
a { color: var(--ink); text-decoration: none; }
.shell { max-width: 1100px; margin: 0 auto; padding: 24px 32px; }

/* Header */
.shell-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 16px 0; border-bottom: 1px solid var(--line); margin-bottom: 32px;
}
.shell-brand { display: flex; align-items: center; gap: 14px; }
.shell-brand img { height: 44px; width: auto; }
.shell-brand .meta .name { font-family: var(--display); font-size: 14px; font-weight: 700; line-height: 1; }
.shell-brand .meta .tag  { font-size: 10px; color: var(--ink-soft); margin-top: 4px; letter-spacing: 0.04em; }
.shell-nav { display: flex; gap: 6px; align-items: center; flex-wrap: wrap; }
.shell-nav a { font-size: 13px; padding: 8px 14px; border-radius: 8px; color: var(--ink-soft); }
.shell-nav a:hover { background: var(--paper-warm); color: var(--ink); }
.shell-nav .home { background: var(--ink); color: var(--paper); }
.shell-nav .home:hover { background: var(--ink-soft); color: var(--paper); }

/* Language toggle (ID/EN) — shared across standalone pages */
.lang-toggle {
  display: inline-flex;
  margin-left: 6px;
  background: var(--paper-warm);
  border-radius: 999px;
  padding: 3px;
  font-family: var(--mono);
  font-size: 11px;
  font-weight: 600;
  border: 1px solid var(--line);
}
.lang-btn {
  background: transparent; border: none; padding: 5px 10px;
  border-radius: 999px; cursor: pointer; color: var(--ink-soft);
  letter-spacing: 0.04em; transition: all 0.15s;
  font-family: inherit; font-size: inherit; font-weight: inherit;
}
.lang-btn:hover { color: var(--ink); }
.lang-btn.active { background: var(--ink); color: var(--paper); }

/* Hero */
.hero {
  padding: 48px 0;
}
.hero .eyebrow {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--mono); font-size: 11px; letter-spacing: 0.1em; text-transform: uppercase;
  background: var(--paper-warm); padding: 6px 12px; border-radius: 999px; color: var(--ink-soft);
}
.hero h1 { font-family: var(--display); font-size: clamp(34px, 6vw, 56px); font-weight: 800; letter-spacing: -0.02em; line-height: 1.05; margin: 16px 0; }
.hero h1 em { color: var(--gold-deep); font-style: normal; }
.hero .lead { font-size: 17px; color: var(--ink-soft); max-width: 640px; }

/* Card */
.card {
  background: white; border: 1px solid var(--line); border-radius: 16px; padding: 28px; margin-bottom: 18px;
  box-shadow: 0 1px 0 rgba(14,27,44,0.04), 0 12px 32px -16px rgba(14,27,44,0.18);
}
.card h2, .card h3 { font-family: var(--display); margin-bottom: 12px; }

/* Button */
.btn {
  display: inline-flex; align-items: center; gap: 8px; padding: 12px 22px;
  border-radius: 999px; font-weight: 600; font-size: 14px; cursor: pointer;
  border: none; transition: all 0.2s; text-decoration: none;
}
.btn-primary { background: var(--ink); color: var(--paper); }
.btn-primary:hover { background: var(--gold-deep); color: var(--paper); }
.btn-ghost { background: transparent; color: var(--ink); border: 1px solid var(--line); }
.btn-ghost:hover { background: var(--paper-warm); }

/* Coming soon banner */
.coming-soon {
  background: linear-gradient(135deg, var(--ink) 0%, var(--ink-soft) 100%);
  color: var(--paper); padding: 32px; border-radius: 16px; margin: 24px 0;
}
.coming-soon h2 { color: var(--paper); }
.coming-soon p { color: rgba(246,241,231,0.85); }

/* Footer */
.shell-footer {
  margin-top: 64px; padding: 32px 0; border-top: 1px solid var(--line);
  font-size: 12px; color: var(--ink-soft); display: flex; justify-content: space-between; flex-wrap: wrap; gap: 16px;
}
.shell-footer .left strong { color: var(--ink); }

@media (max-width: 700px) {
  .shell { padding: 18px 18px; }
  .shell-header { flex-direction: column; align-items: flex-start; gap: 16px; }
}
