




:root {
  
  --teal-primary: #04175C;
  --teal-light: #e8eaf2;
  --teal-dark: #030f3d;

  --primary-navy: #04175C;
  --primary-navy-dark: #030f3d;
  --sky-blue: #0ea5e9;
  --sky-blue-hover: #0284c7;

  --amber-primary: #f59e0b;
  --amber-light: #fef3c7;
  --amber-border: #f59e0b;
  --amber-text: #b45309;
  --accent-gold: var(--amber-primary);

  --bg-page: #FDFCFA;
  --batik-kawung: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='60' height='60' viewBox='0 0 60 60'%3E%3Cpath d='M30,0 C38,10 38,20 30,30 C22,20 22,10 30,0 Z M30,30 C38,40 38,50 30,60 C22,50 22,40 30,30 Z M0,30 C10,38 20,38 30,30 C20,22 10,22 0,30 Z M30,30 C40,38 50,38 60,30 C50,22 40,22 30,30 Z' fill='none' stroke='%238c6239' stroke-opacity='0.08' stroke-width='0.8'/%3E%3Ccircle cx='30' cy='30' r='2' fill='%238c6239' opacity='0.08'/%3E%3C/svg%3E");
  --batik-kawung-light: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='60' height='60' viewBox='0 0 60 60'%3E%3Cpath d='M30,0 C38,10 38,20 30,30 C22,20 22,10 30,0 Z M30,30 C38,40 38,50 30,60 C22,50 22,40 30,30 Z M0,30 C10,38 20,38 30,30 C20,22 10,22 0,30 Z M30,30 C40,38 50,38 60,30 C50,22 40,22 30,30 Z' fill='none' stroke='%230ea5e9' stroke-opacity='0.1' stroke-width='0.8'/%3E%3Ccircle cx='30' cy='30' r='2' fill='%230ea5e9' opacity='0.1'/%3E%3C/svg%3E");
  --bg-surface: #F9F6F2;
  --bg-neutral: #F3EFE9;

  --text-primary: #1C1916;
  --text-body: #4A4542;
  --text-muted: #9C958E;
  --text-link: #04175C;

  --border-default: #E8E2DA;
  --border-focus: var(--teal-primary);

  --footer-bg: #04175C;

  
  --badge-tayang-bg: #e8eaf2;
  --badge-tayang-text: #04175C;
  --badge-diproses-bg: #FDF3E8;
  --badge-diproses-text: #B8620A;
  --badge-dikirim-bg: #EAF2FC;
  --badge-dikirim-text: #1A5E9C;
  --badge-habis-bg: #FDECEA;
  --badge-habis-text: #B52A2A;
  --badge-hidden-bg: #F3EFE9;
  --badge-hidden-text: #6B6560;

  
  --color-success: #1D9E75;
  --color-error: #B52A2A;
  --color-error-bg: #FDECEA;
  --color-warning: #E8943A;
  --color-info: #1A5E9C;

  
  --font-family: 'Plus Jakarta Sans', system-ui, sans-serif;

  --text-xs: 11px;
  --text-sm: 12px;
  --text-base: 15px;
  --text-md: 16px;
  --text-lg: 18px;
  --text-xl: 24px;
  --text-2xl: 28px;
  --text-3xl: 32px;
  --text-4xl: 40px;
  --text-5xl: 48px;

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

  --lh-body: 1.6;
  --lh-heading: 1.2;
  --lh-relaxed: 1.75;

  
  --space-1: 4px;
  --space-2: 8px;
  --space-3: 12px;
  --space-4: 16px;
  --space-5: 20px;
  --space-6: 24px;
  --space-8: 32px;
  --space-10: 40px;
  --space-12: 48px;
  --space-16: 64px;
  --space-20: 80px;
  --space-24: 96px;

  
  --navbar-h: 110px;
  --sidebar-w: 220px;
  --container-max: 1280px;
  --radius-sm: 6px;
  --radius-md: 8px;
  --radius-lg: 12px;
  --radius-xl: 16px;
  --radius-full: 9999px;

  
  --shadow-xs: 0 1px 2px rgba(28, 25, 22, 0.06);
  --shadow-sm: 0 2px 8px rgba(28, 25, 22, 0.08);
  --shadow-md: 0 4px 16px rgba(28, 25, 22, 0.10);
  --shadow-lg: 0 8px 32px rgba(28, 25, 22, 0.12);
  --shadow-teal: 0 4px 20px rgba(4, 23, 92, 0.18);

  
  --ease-ui: cubic-bezier(0.16, 1, 0.3, 1);
  --ease-spring: cubic-bezier(0.34, 1.56, 0.64, 1);
  --ease-out: ease-out;
  --ease-in: ease-in;
  --dur-fast: 80ms;
  --dur-base: 150ms;
  --dur-slow: 200ms;
  --dur-modal: 280ms;
  --dur-panel: 320ms;
  --dur-toast: 320ms;

  
  --z-base: 0;
  --z-above: 10;
  --z-sticky: 20;
  --z-overlay: 40;
  --z-modal: 100;
  --z-toast: 1000;
}

@media (max-width: 1023px) {
  :root {
    --navbar-h: 60px;
  }
}

@media (max-width: 767px) {
  :root {
    --text-xl: 20px;
    --text-2xl: 22px;
    --text-3xl: 24px;
    --text-4xl: 28px;
    --text-5xl: 32px;
  }
}