/* =============================================================
   ceritakita.id · DESIGN SYSTEM — INLINED
   tokens/colors.css + tokens/typography.css + tokens/spacing.css
   + guidelines/base.css  (all in one file, zero @import needed)
   ============================================================= */

@import url("https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:ital,wght@0,400;0,500;0,600;0,700;0,800;1,400;1,500;1,600;1,700&display=swap");

/* ─── COLOR TOKENS ─────────────────────────────────────────── */
:root {
  /* IVORY / PAPER */
  --paper:        #FBF6EC;
  --paper-2:      #F6EEDD;
  --cream:        #F1E6D0;
  --cream-deep:   #E8D8BC;
  --surface:      #FFFCF6;

  /* MAROON / ROSE TUA */
  --maroon-900:   #38101A;
  --maroon-800:   #4E1620;
  --maroon-700:   #6A1F2B;
  --maroon-600:   #84293A;
  --rose-500:     #A8475A;
  --rose-300:     #C98C97;
  --rose-100:     #EFD9DC;

  /* EMAS / GOLD */
  --gold-700:     #8A6A2F;
  --gold-600:     #A9853F;
  --gold-500:     #C2A05A;
  --gold-400:     #D4B978;
  --gold-200:     #E7D6AC;

  /* INK */
  --ink:          #2C1B1D;
  --ink-soft:     #5B4347;
  --ink-mute:     #8C7579;
  --on-dark:      #F4E9D8;
  --on-dark-soft: #D8BFC2;

  /* SEMANTIC */
  --success:      #4E7C59;
  --success-bg:   #E4EFE5;
  --warn:         #B5852E;
  --warn-bg:      #F7ECCF;
  --danger:       #A8475A;
  --danger-bg:    #F4E0E3;

  /* ROLE ALIASES */
  --bg:           var(--paper);
  --bg-panel:     var(--paper-2);
  --line:         #E4D6BC;
  --line-soft:    #EFE4CC;
  --line-gold:    var(--gold-200);
  --text-strong:  var(--ink);
  --text-body:    var(--ink-soft);
  --text-mute:    var(--ink-mute);
  --text-on-dark: var(--on-dark);
  --accent:       var(--maroon-700);
  --accent-hover: var(--maroon-600);
  --accent-gold:  var(--gold-500);
  --ground-dark:  var(--maroon-900);
  --ring:         0 0 0 3px rgba(168,71,90,.28);
}

/* ─── TYPOGRAPHY TOKENS ─────────────────────────────────────── */
:root {
  --font-display: "Plus Jakarta Sans", system-ui, -apple-system, sans-serif;
  --font-title:   "Plus Jakarta Sans", system-ui, -apple-system, sans-serif;
  --font-body:    "Plus Jakarta Sans", system-ui, -apple-system, sans-serif;

  --fs-hero:    clamp(44px, 7vw, 86px);
  --fs-h1:      clamp(34px, 5vw, 58px);
  --fs-h2:      clamp(28px, 3.6vw, 44px);
  --fs-h3:      24px;
  --fs-lead:    clamp(16px, 1.6vw, 19px);
  --fs-body:    16px;
  --fs-sm:      14px;
  --fs-xs:      12.5px;
  --fs-eyebrow: 13px;

  --lh-tight:   1.05;
  --lh-snug:    1.18;
  --lh-normal:  1.5;
  --lh-relaxed: 1.7;

  --track-eyebrow: 0.34em;
  --track-title:   0.04em;
  --track-body:    0em;

  --fw-regular:  400;
  --fw-medium:   500;
  --fw-semibold: 600;
  --fw-bold:     700;
  --fw-black:    800;
}

/* ─── SPACING · RADII · ELEVATION · MOTION ─────────────────── */
:root {
  --sp-1: 4px;   --sp-2: 8px;   --sp-3: 12px;  --sp-4: 16px;
  --sp-5: 20px;  --sp-6: 24px;  --sp-8: 32px;  --sp-10: 40px;
  --sp-12: 48px; --sp-16: 64px; --sp-20: 80px; --sp-24: 96px;
  --sp-32: 128px;

  --r-sm:    8px;
  --r-md:    14px;
  --r-lg:    22px;
  --r-xl:    32px;
  --r-pill:  999px;
  --r-phone: 44px;

  --shadow-1:    0 1px 2px rgba(56,16,26,.05), 0 1px 1px rgba(56,16,26,.04);
  --shadow-2:    0 6px 18px rgba(56,16,26,.07), 0 2px 5px rgba(56,16,26,.05);
  --shadow-3:    0 18px 44px rgba(56,16,26,.12), 0 4px 10px rgba(56,16,26,.06);
  --shadow-gold: 0 16px 40px rgba(138,106,47,.22);
  --shadow-phone:0 40px 90px -20px rgba(56,16,26,.40), 0 12px 30px rgba(56,16,26,.18);

  --container: 1180px;
  --gutter:    24px;

  --ease:      cubic-bezier(.16,.84,.36,1);
  --ease-soft: cubic-bezier(.4,0,.2,1);
  --dur-fast:  160ms;
  --dur:       240ms;
  --dur-slow:  420ms;
}

/* ─── BASE RESET ────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
body {
  margin: 0;
  background: var(--bg);
  color: var(--text-strong);
  font-family: var(--font-body);
  font-size: var(--fs-body);
  line-height: var(--lh-normal);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
img  { max-width: 100%; display: block; }
a    { color: inherit; text-decoration: none; }
ul   { list-style: none; margin: 0; padding: 0; }
button { font-family: inherit; cursor: pointer; }

/* ─── TYPE HELPERS ──────────────────────────────────────────── */
.eyebrow {
  font-family: var(--font-title);
  font-size: var(--fs-eyebrow);
  letter-spacing: var(--track-eyebrow);
  text-transform: uppercase;
  color: var(--gold-700);
  font-weight: var(--fw-semibold);
  display: inline-flex;
  align-items: center;
  gap: var(--sp-3);
}
.eyebrow::before,
.eyebrow.center::after {
  content: "";
  width: 28px; height: 1px;
  background: var(--gold-500);
  display: inline-block;
}
.display {
  font-family: var(--font-display);
  font-weight: var(--fw-semibold);
  line-height: var(--lh-tight);
  letter-spacing: var(--track-title);
  color: var(--text-strong);
}
.display .accent { font-style: italic; color: var(--accent); }

/* ─── BUTTONS ───────────────────────────────────────────────── */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: var(--sp-2);
  font-family: var(--font-body); font-weight: var(--fw-semibold); font-size: var(--fs-sm);
  letter-spacing: .01em; line-height: 1; white-space: nowrap;
  padding: 15px 26px; border-radius: var(--r-pill); border: 1px solid transparent;
  transition: transform var(--dur-fast) var(--ease), box-shadow var(--dur) var(--ease),
              background var(--dur) var(--ease), color var(--dur) var(--ease);
}
.btn:focus-visible { outline: none; box-shadow: var(--ring); }

.btn-primary { background: var(--accent); color: var(--paper); box-shadow: var(--shadow-2); }
.btn-primary:hover { background: var(--accent-hover); transform: translateY(-2px); box-shadow: var(--shadow-3); }
.btn-primary:active { transform: translateY(0); box-shadow: var(--shadow-1); }

.btn-gold { background: linear-gradient(180deg, var(--gold-400), var(--gold-600)); color: var(--maroon-900); box-shadow: var(--shadow-gold); }
.btn-gold:hover { transform: translateY(-2px); filter: brightness(1.04); }

.btn-ghost { background: transparent; color: var(--accent); border-color: var(--cream-deep); }
.btn-ghost:hover { border-color: var(--accent); background: rgba(106,31,43,.04); }

.btn-outline-gold { background: transparent; color: var(--gold-700); border-color: var(--gold-500); }
.btn-outline-gold:hover { background: var(--gold-500); color: var(--maroon-900); }

.btn-wa { background: #25D366; color: #fff; border-color: #25D366; box-shadow: var(--shadow-2); }
.btn-wa:hover { background: #128C7E; border-color: #128C7E; transform: translateY(-2px); box-shadow: var(--shadow-3); }

.btn-sm    { padding: 11px 18px; font-size: var(--fs-xs); }
.btn-lg    { padding: 18px 32px; font-size: var(--fs-body); }
.btn-block { width: 100%; }
.btn-ic svg { width: 17px; height: 17px; display: block; }

/* ─── LAYOUT ─────────────────────────────────────────────────── */
.container { width: 100%; max-width: var(--container); margin-inline: auto; padding-inline: var(--gutter); }
section { position: relative; }

/* ─── ORNAMENTAL DIVIDER ─────────────────────────────────────── */
.flourish { display: inline-flex; align-items: center; gap: 10px; color: var(--gold-500); }
.flourish::before, .flourish::after { content: ""; width: 54px; height: 1px; background: linear-gradient(90deg, transparent, var(--gold-500)); }
.flourish::after { background: linear-gradient(90deg, var(--gold-500), transparent); }

/* ─── BADGE ──────────────────────────────────────────────────── */
.ck-badge {
  display: inline-flex; align-items: center; gap: 6px;
  font-family: var(--font-body); font-size: 11px; font-weight: var(--fw-bold);
  letter-spacing: .16em; text-transform: uppercase;
  padding: 7px 16px; border-radius: var(--r-pill);
}
.ck-badge-gold   { background: linear-gradient(180deg, var(--gold-400), var(--gold-600)); color: var(--maroon-900); box-shadow: var(--shadow-gold); }
.ck-badge-maroon { background: var(--accent); color: var(--paper); }
.ck-badge-soft   { background: var(--rose-100); color: var(--maroon-700); }

/* ─── REVEAL ANIMATION ───────────────────────────────────────── */
.reveal { opacity: 0; transform: translateY(18px); transition: opacity .7s var(--ease), transform .7s var(--ease); }
.reveal.in { opacity: 1; transform: none; }
