/*
Theme Name: keiko
Theme URI: https://keiko.id
Author: Andika Setiawan
Author URI: https://keiko.id
Description: Tema kustom keiko untuk agensi visa & event Jepang-Indonesia. Termasuk konten Visa, Portfolio, Service, panel tema, konsultasi, dan sample konten otomatis saat aktivasi. Tidak memerlukan plugin tambahan.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.6
Requires PHP: 7.4
License: GPL-2.0-or-later
Text Domain: keiko
*/

/* Tailwind di-load via CDN di header.php — file ini berisi token desain + komponen yang sama persis dengan versi React. */

:root {
  --background: #ffffff;
  --foreground: #09090b;
  --surface: #ffffff;
  --surface-muted: #fafafa;
  --border-color: #e4e4e7;
  --muted: #f4f4f5;
  --muted-foreground: #71717b;
  --primary: #019d91;
  --primary-foreground: #ffffff;
  --accent-yellow: #f0b100;
  --accent-blue: #3a86ff;
  --accent-pink: #ff8eed;
  --accent-green: #94d19f;
  --aqua: #00ddb3;
  --shadow-subtle: 0 1px 2px 0 rgba(0,0,0,0.05);
  --shadow-card: 0 4px 16px -4px rgba(0,0,0,0.06);
}
.dark {
  --background: #09090b;
  --foreground: #fafafa;
  --surface: #18181b;
  --surface-muted: #131316;
  --border-color: #27272a;
  --muted: #1f1f23;
  --muted-foreground: #a1a1aa;
  --primary: #00ddb3;
  --primary-foreground: #09090b;
}

* { border-color: var(--border-color); box-sizing: border-box; }
html { font-family: 'Inter', ui-sans-serif, system-ui, sans-serif; -webkit-font-smoothing: antialiased; }
body { margin: 0; background: var(--background); color: var(--foreground); font-size: 16px; letter-spacing: 0; }
a { color: inherit; text-decoration: none; }
h1,h2,h3,h4 { font-family: 'DM Sans', ui-sans-serif, system-ui, sans-serif; color: var(--foreground); font-weight: 600; margin: 0; }
h1 { letter-spacing: 0; line-height: 1.15; }
h2 { letter-spacing: 0; line-height: 1.2; }
h3 { letter-spacing: 0; line-height: 1.25; }
::selection { background: var(--primary); color: var(--primary-foreground); }
img { max-width: 100%; height: auto; display: block; }

.font-display { font-family: 'DM Sans', ui-sans-serif, system-ui, sans-serif; }
.text-muted-foreground { color: var(--muted-foreground); }

.container-page { max-width: 1200px; margin-inline: auto; padding-inline: 24px; }

.btn-primary { display: inline-flex; align-items: center; justify-content: center; gap: 8px; background: var(--primary); color: var(--primary-foreground); border-radius: 12px; padding: 12px 24px; font-weight: 500; font-size: 16px; transition: transform .15s ease, filter .15s ease, box-shadow .15s ease; box-shadow: var(--shadow-subtle); border: 0; cursor: pointer; }
.btn-primary:hover { filter: brightness(1.05); transform: translateY(-1px); box-shadow: var(--shadow-card); }
.btn-outline { display: inline-flex; align-items: center; justify-content: center; gap: 8px; background: var(--surface); color: var(--foreground); border: 1px solid var(--border-color); border-radius: 8px; padding: 10px 20px; font-weight: 500; font-size: 15px; transition: background .15s ease; cursor: pointer; }
.btn-outline:hover { background: var(--muted); }
.btn-ghost { display: inline-flex; align-items: center; justify-content: center; color: var(--muted-foreground); border-radius: 6px; padding: 6px 16px; font-weight: 500; font-size: 15px; transition: color .15s, background .15s; border: 0; background: transparent; cursor: pointer; }
.btn-ghost:hover, .btn-ghost.active { color: var(--foreground); background: var(--muted); }

.card-surface { background: var(--surface); border-radius: 16px; box-shadow: var(--shadow-subtle); border: 1px solid var(--border-color); padding: 32px; }
.input-field { width: 100%; background: var(--surface-muted); border: 1px solid var(--border-color); border-radius: 8px; padding: 12px 14px; font-size: 15px; color: var(--foreground); transition: border-color .15s, box-shadow .15s; font-family: inherit; }
.input-field::placeholder { color: #9f9fa9; }
.input-field:focus { outline: none; border-color: var(--primary); box-shadow: 0 0 0 3px color-mix(in oklab, var(--primary) 15%, transparent); }
.chip { display: inline-flex; align-items: center; gap: 6px; background: var(--muted); color: var(--foreground); border-radius: 999px; padding: 6px 14px; font-size: 13px; font-weight: 500; }

.float-blob { animation: floaty 6s ease-in-out infinite; }
@keyframes floaty { 0%,100% { transform: translateY(0) rotate(0deg); } 50% { transform: translateY(-12px) rotate(2deg); } }

/* Header */
.site-header { position: sticky; top: 0; z-index: 40; backdrop-filter: blur(8px); background: color-mix(in oklab, var(--background) 85%, transparent); border-bottom: 1px solid var(--border-color); }
.site-header .row { display: flex; height: 64px; align-items: center; justify-content: space-between; gap: 16px; }
.brand { display: flex; align-items: center; gap: 8px; }
.brand .logo { height: 32px; width: 32px; border-radius: 12px; display: flex; align-items: center; justify-content: center; background: var(--primary); color: #fff; font-family: 'DM Sans'; font-weight: 600; }
.brand .logo img { height: 32px; width: 32px; object-fit: contain; border-radius: 12px; }
.brand-wordmark { display: flex; align-items: center; width: min(300px, 52vw); height: 36px; }
.brand-wordmark img { width: 100%; height: 100%; object-fit: contain; object-position: left center; }
.logo-dark { display: none; }
.dark .logo-light { display: none; }
.dark .logo-dark { display: block; }
.brand .name { font-family: 'DM Sans'; font-weight: 600; font-size: 15px; line-height: 1.1; }
.brand .sub { font-size: 10px; color: var(--muted-foreground); margin-top: -2px; }
.nav-main { display: none; gap: 4px; align-items: center; }
.lang-toggle { display: flex; align-items: center; background: var(--muted); border-radius: 8px; padding: 2px; }
.lang-toggle button { padding: 4px 10px; border-radius: 6px; font-size: 12px; font-weight: 500; border: 0; background: transparent; color: var(--muted-foreground); cursor: pointer; }
.lang-toggle button.active { background: var(--surface); color: var(--foreground); box-shadow: var(--shadow-subtle); }
.icon-btn { height: 36px; width: 36px; border-radius: 8px; display: inline-flex; align-items: center; justify-content: center; border: 1px solid var(--border-color); background: var(--surface); cursor: pointer; }
.theme-sun { display: none; }
.dark .theme-sun { display: block; }
.dark .theme-moon { display: none; }
.dark .theme-sun { color: var(--accent-yellow); }
.header-tools { display: none; gap: 8px; align-items: center; }
.mobile-header-tools { display: flex; align-items: center; gap: 8px; }
.mobile-bottom-nav { position: fixed; left: 12px; right: 12px; bottom: 12px; z-index: 60; display: grid; grid-template-columns: repeat(4, 1fr); gap: 4px; padding: 8px; border: 1px solid var(--border-color); border-radius: 18px; background: color-mix(in oklab, var(--surface) 92%, transparent); box-shadow: 0 16px 40px rgba(0,0,0,0.12); backdrop-filter: blur(14px); }
.mobile-bottom-nav a { min-height: 52px; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 4px; border-radius: 12px; color: var(--muted-foreground); font-size: 11px; font-weight: 600; }
.mobile-bottom-nav a.active { color: var(--primary); background: color-mix(in oklab, var(--primary) 12%, transparent); }
.mobile-bottom-nav svg { width: 20px; height: 20px; }
@media (min-width: 768px) {
  .nav-main, .header-tools { display: flex; }
  .mobile-header-tools, .mobile-bottom-nav { display: none; }
}
@media (max-width: 767px) {
  body { padding-bottom: 92px; }
  .site-header .row { height: 60px; }
  .brand-wordmark { width: min(250px, 48vw); height: 30px; }
}

/* Sections */
.hero { padding: 48px 0 80px; }
.hero .grid { display: grid; gap: 48px; align-items: center; }
@media (min-width: 768px) { .hero { padding: 80px 0; } .hero .grid { grid-template-columns: 1fr 1fr; } }
.hero h1 { font-size: 40px; line-height: 1.05; margin-top: 12px; font-weight: 600; }
@media (min-width: 768px) { .hero h1 { font-size: 60px; } }
.hero .tagline { font-size: 14px; font-weight: 500; color: var(--muted-foreground); margin-top: 24px; }
.hero .desc { margin-top: 24px; font-size: 18px; color: var(--muted-foreground); max-width: 36rem; }
.hero .cta { margin-top: 32px; display: flex; flex-wrap: wrap; gap: 12px; }
.hero .chip { background: color-mix(in oklab, var(--primary) 12%, transparent); color: var(--primary); }
.hero .chip .dot { height: 6px; width: 6px; border-radius: 999px; background: var(--primary); }

.hero-illustration { position: relative; aspect-ratio: 1/1; width: 100%; max-width: 520px; margin: 0 auto; }
.hero-illustration .bg { position: absolute; inset: 0; border-radius: 28px; background: linear-gradient(135deg, color-mix(in oklab, var(--primary) 12%, var(--surface)), color-mix(in oklab, var(--accent-yellow) 10%, var(--surface))); border: 1px solid var(--border-color); }
.hero-illustration .b1, .hero-illustration .b2, .hero-illustration .b3, .hero-illustration .b4 { display: none; }
.hero-illustration .img-wrap { position: absolute; inset: 0; display: flex; align-items: center; justify-content: center; padding: 40px; }
.hero-illustration img { width: 100%; height: 100%; object-fit: contain; filter: drop-shadow(0 20px 25px rgba(0,0,0,0.15)); }

.section { padding: 80px 0; }
.section-muted { background: var(--surface-muted); border-top: 1px solid var(--border-color); border-bottom: 1px solid var(--border-color); padding: 56px 0; }
.section h2 { font-size: 30px; font-weight: 600; }
@media (min-width: 768px) { .section h2 { font-size: 48px; } }
.section .lead { margin-top: 16px; color: var(--muted-foreground); max-width: 42rem; }

.grid-4 { margin-top: 48px; display: grid; gap: 24px; grid-template-columns: repeat(2, 1fr); }
@media (min-width: 768px) { .grid-4 { grid-template-columns: repeat(4, 1fr); } }
.grid-3 { margin-top: 48px; display: grid; gap: 24px; grid-template-columns: 1fr; }
@media (min-width: 768px) { .grid-3 { grid-template-columns: repeat(3, 1fr); } }
.grid-2x { margin-top: 48px; display: grid; gap: 24px; grid-template-columns: 1fr; }
@media (min-width: 768px) { .grid-2x { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .grid-2x { grid-template-columns: repeat(3, 1fr); } }

.stat-val { font-family: 'DM Sans'; font-size: 36px; font-weight: 600; letter-spacing: 0; color: var(--primary); }
@media (min-width: 768px) { .stat-val { font-size: 48px; } }
.stat-lbl { margin-top: 8px; font-size: 14px; color: var(--muted-foreground); }

.card-icon { display: inline-flex; height: 40px; min-width: 40px; padding: 0 12px; align-items: center; justify-content: center; border-radius: 8px; color: #fff; font-size: 13px; font-weight: 600; letter-spacing: 0; }
.card-title { margin-top: 20px; font-family: 'DM Sans'; font-size: 20px; font-weight: 600; }
.card-desc { margin-top: 8px; font-size: 14px; color: var(--muted-foreground); }
.card-surface.hover-lift { transition: transform .2s; }
.card-surface.hover-lift:hover { transform: translateY(-4px); }

.flow-card { position: relative; }
.flow-num { position: absolute; top: -12px; right: -12px; height: 40px; width: 40px; border-radius: 999px; display: flex; align-items: center; justify-content: center; font-family: 'DM Sans'; font-weight: 600; color: #fff; background: var(--primary); }
.flow-kicker { font-size: 12px; font-weight: 600; color: var(--primary); text-transform: uppercase; letter-spacing: 0; }

.svc-card { position: relative; overflow: hidden; }
.svc-blob { position: absolute; inset: 0 0 auto auto; width: 100%; height: 3px; opacity: 1; }
.svc-card > .inner { position: relative; }

/* Contact */
.contact-card { padding: 0 !important; overflow: hidden; display: grid; grid-template-columns: 1fr; }
@media (min-width: 768px) { .contact-card { grid-template-columns: 1fr 1fr; } }
.contact-left { padding: 32px; background: linear-gradient(135deg, var(--primary), color-mix(in oklab, var(--primary) 60%, var(--accent-blue))); color: #fff; }
@media (min-width: 768px) { .contact-left { padding: 48px; } .contact-form { padding: 48px !important; } }
.contact-left h2 { color: #fff !important; font-size: 30px; font-weight: 600; }
@media (min-width: 768px) { .contact-left h2 { font-size: 36px; } }
.contact-left .desc { margin-top: 12px; opacity: 0.9; }
.contact-left ul { margin-top: 32px; padding: 0; list-style: none; font-size: 14px; opacity: 0.95; display: flex; flex-direction: column; gap: 12px; }
.contact-form { padding: 32px; display: flex; flex-direction: column; gap: 16px; }
.contact-form label { font-size: 14px; font-weight: 500; display: block; }
.contact-form .row2 { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.contact-sent { text-align: center; padding: 48px 0; display: flex; flex-direction: column; align-items: center; }
.contact-sent .check { height: 56px; width: 56px; border-radius: 999px; display: flex; align-items: center; justify-content: center; margin-bottom: 16px; background: color-mix(in oklab, var(--primary) 18%, transparent); color: var(--primary); }

/* Visa list */
.visa-row { display: grid; gap: 32px; grid-template-columns: 1fr; align-items: start; }
@media (min-width: 768px) { .visa-row { grid-template-columns: auto 1fr 1fr; } }
.visa-icon { height: 64px; width: 64px; border-radius: 12px; display: inline-flex; align-items: center; justify-content: center; color: #fff; font-family: 'DM Sans'; font-size: 18px; font-weight: 700; }
.req-label { font-size: 11px; font-weight: 500; text-transform: uppercase; letter-spacing: 0; color: var(--muted-foreground); margin-bottom: 12px; }
.req-list { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 8px; }
.req-list li { display: flex; gap: 8px; font-size: 14px; }
.req-list svg { flex-shrink: 0; margin-top: 2px; color: var(--primary); }

/* Portfolio */
.pf-grid { margin-top: 48px; display: grid; gap: 24px; grid-template-columns: 1fr; }
@media (min-width: 640px) { .pf-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .pf-grid { grid-template-columns: repeat(3, 1fr); } }
.pf-card { padding: 0 !important; overflow: hidden; }
.pf-cover { aspect-ratio: 4/3; position: relative; display: flex; align-items: center; justify-content: center; background-size: cover; background-position: center; }
.pf-cover.has-image::after { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, rgba(0,0,0,0.05), rgba(0,0,0,0.35)); }
.pf-cover .num { height: 80px; width: 80px; border-radius: 16px; background: rgba(255,255,255,0.2); backdrop-filter: blur(6px); display: flex; align-items: center; justify-content: center; font-family: 'DM Sans'; font-size: 24px; color: #fff; }
.pf-cover.has-image .num { position: relative; z-index: 1; }
.pf-meta { padding: 24px; }
.pf-meta .info { margin-top: 12px; display: flex; gap: 16px; font-size: 12px; color: var(--muted-foreground); }
.pf-meta .info span { display: inline-flex; align-items: center; gap: 6px; }

/* About */
.about-grid { margin-top: 56px; display: grid; gap: 24px; grid-template-columns: 1fr; }
@media (min-width: 768px) { .about-grid { grid-template-columns: repeat(3, 1fr); } }
.about-legal { margin-top: 64px; }
.about-legal dl { display: grid; grid-template-columns: 1fr; gap: 12px 48px; font-size: 14px; margin: 0; }
@media (min-width: 768px) { .about-legal dl { grid-template-columns: 1fr 1fr; } }
.about-legal .row { display: flex; justify-content: space-between; border-bottom: 1px solid var(--border-color); padding: 8px 0; }
.about-legal dt { color: var(--muted-foreground); margin: 0; }
.about-legal dd { margin: 0; }

/* Footer */
.site-footer { margin-top: 96px; border-top: 1px solid var(--border-color); background: var(--surface-muted); }
.site-footer .cols { padding: 64px 0; display: grid; gap: 48px; grid-template-columns: 1fr; }
@media (min-width: 768px) { .site-footer .cols { grid-template-columns: repeat(3, 1fr); } }
.site-footer h4 { font-family: 'DM Sans'; font-weight: 600; margin-bottom: 16px; font-size: 16px; }
.site-footer ul { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 8px; font-size: 14px; }
.site-footer .copy { border-top: 1px solid var(--border-color); padding: 24px 0; font-size: 12px; color: var(--muted-foreground); }
.site-footer .brand-row { display: flex; align-items: center; gap: 8px; margin-bottom: 16px; }
.site-footer .brand-row .logo { height: 36px; width: 36px; border-radius: 12px; display: flex; align-items: center; justify-content: center; background: var(--primary); color: #fff; font-family: 'DM Sans'; font-weight: 600; }
.site-footer .brand-row .logo img { height: 36px; width: 36px; border-radius: 12px; object-fit: contain; }
.site-footer .footer-wordmark { width: min(300px, 100%); height: 36px; }
.site-footer .brand-row .name { font-family: 'DM Sans'; font-size: 18px; font-weight: 600; }
.site-footer .ctrow { display: flex; gap: 8px; align-items: flex-start; }
.site-footer .ctrow svg { color: var(--primary); flex-shrink: 0; margin-top: 2px; }

.alert-ok { background: color-mix(in oklab, var(--primary) 10%, transparent); color: var(--primary); border-radius: 8px; padding: 12px 14px; font-size: 14px; }
.alert-err { background: #fee; color: #b91c1c; border-radius: 8px; padding: 12px 14px; font-size: 14px; }
