/* ── VARIABEL GRAND DESIGN ── */
:root {
  --ink: #1a1814; --paper: #f7f3ec; --paper2: #ede9e0;
  --green: #1d7a55; --green-b: #22c97a;
  --muted: #5f6368; --border: #dadce0;
  --serif: 'Playfair Display', Georgia, serif;
  --sans: 'DM Sans', system-ui, -apple-system, sans-serif;
  --mono: 'DM Mono', monospace;
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
body {
  font-family: var(--sans); background: var(--paper); color: var(--ink);
  min-height: 100vh; display: flex; flex-direction: column; overflow-x: hidden;
}
a { text-decoration: none; }

/* ── TAMPILAN AWAL (HOME VIEW) ── */
#homeView {
  flex: 1; display: flex; flex-direction: column; align-items: center; justify-content: center; padding: 20px; position: relative;
}

/* Navigasi Atas */
.home-nav {
  position: absolute; top: 0; left: 0; right: 0; padding: 20px 32px; display: flex; justify-content: flex-end; gap: 20px;
}
.home-nav a { font-size: 14px; color: var(--ink); }
.home-nav a:hover { text-decoration: underline; }

/* Logo */
.home-logo {
  font-family: var(--serif); font-size: clamp(48px, 6vw, 72px); color: var(--ink); margin-bottom: 32px; letter-spacing: -1px; text-align: center; line-height: 1.1;
}
.home-logo em { color: var(--green); font-style: italic; }
.home-logo span { 
  display: block; font-family: var(--mono); font-size: 14px; color: var(--muted); letter-spacing: 0.2em; text-transform: uppercase; margin-top: 8px;
}

/* Search Box Utama */
.search-box-home {
  width: 100%; max-width: 640px; display: flex; align-items: center; background: #fff; border: 1px solid var(--border); border-radius: 32px; padding: 14px 24px; box-shadow: 0 4px 12px rgba(26,24,20,.04); transition: box-shadow 0.2s, border-color 0.2s; margin-bottom: 32px;
}
.search-box-home:hover, .search-box-home:focus-within {
  box-shadow: 0 6px 16px rgba(26,24,20,.1); border-color: rgba(223,225,229,0);
}
.search-box-home svg { color: #9aa0a6; margin-right: 14px; }
.search-box-home input {
  flex: 1; min-width: 0; border: none; outline: none; font-size: 16px; font-family: var(--sans); color: var(--ink); background: transparent;
}

/* Chip Saran Pertanyaan */
.suggest-row { display: flex; gap: 10px; flex-wrap: wrap; justify-content: center; max-width: 720px; }
.s-chip {
  background: var(--paper2); border: 1px solid transparent; border-radius: 100px; padding: 8px 16px; font-size: 13px; color: var(--muted); cursor: pointer; transition: all 0.2s; font-family: var(--sans);
  max-width: 100%; white-space: normal; word-break: break-word; overflow-wrap: break-word;
}
.s-chip:hover { background: #fff; border-color: var(--border); color: var(--ink); }

/* Indikator Tech Stack */
.tech-stack {
  position: absolute; bottom: 32px; font-family: var(--mono); font-size: 11px; color: var(--muted); display: flex; gap: 16px; align-items: center; flex-wrap: wrap; justify-content: center;
}
.ts-item { display: flex; align-items: center; gap: 6px; }
.ts-dot { width: 6px; height: 6px; border-radius: 50%; background: var(--green-b); }

/* Responsif */
@media(max-width: 768px) {
  .home-logo { font-size: 40px; }
  .search-box-home { padding: 12px 20px; border-radius: 20px;}
  .tech-stack { position: static; margin-top: 48px; flex-wrap: wrap; justify-content: center; }
}

/* ── LOCAL FONTS (AUTO-DOWNLOADED) ── */
@font-face {
  font-family: 'DM Mono';
  font-style: normal;
  font-weight: 400;
  font-display: optional;
  src: url('/fonts/dm-mono-normal-400.woff2') format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

@font-face {
  font-family: 'DM Mono';
  font-style: normal;
  font-weight: 500;
  font-display: optional;
  src: url('/fonts/dm-mono-normal-500.woff2') format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

@font-face {
  font-family: 'DM Sans';
  font-style: normal;
  font-weight: 400;
  font-display: optional;
  src: url('/fonts/dm-sans-normal-400.woff2') format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

@font-face {
  font-family: 'DM Sans';
  font-style: normal;
  font-weight: 500;
  font-display: optional;
  src: url('/fonts/dm-sans-normal-500.woff2') format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

@font-face {
  font-family: 'DM Sans';
  font-style: normal;
  font-weight: 700;
  font-display: optional;
  src: url('/fonts/dm-sans-normal-700.woff2') format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

@font-face {
  font-family: 'Playfair Display';
  font-style: italic;
  font-weight: 400;
  font-display: optional;
  src: url('/fonts/playfair-display-italic-400.woff2') format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

@font-face {
  font-family: 'Playfair Display';
  font-style: italic;
  font-weight: 700;
  font-display: optional;
  src: url('/fonts/playfair-display-italic-700.woff2') format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

@font-face {
  font-family: 'Playfair Display';
  font-style: normal;
  font-weight: 400;
  font-display: optional;
  src: url('/fonts/playfair-display-normal-400.woff2') format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

@font-face {
  font-family: 'Playfair Display';
  font-style: normal;
  font-weight: 700;
  font-display: optional;
  src: url('/fonts/playfair-display-normal-700.woff2') format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
