/* style.css */
/* =========================================================
   STYLE.CSS – HERO + LOGO CARD + PAKET + MODAL PENAWARAN
   ========================================================= */

:root{
  --accent:#1f6feb;
  --accent-2:#2b7fff;
  --bg:#ffffff;
  --bg-soft:#f5f7fb;
  --text:#0f172a;
  --text-muted:#64748b;
  --text-soft:#334155;
  --card:#ffffff;
  --border:rgba(15,23,42,.10);
  --border-strong:rgba(15,23,42,.18);
  --radius-xl:22px;
  --radius-lg:18px;
  --shadow-1:0 8px 22px rgba(15,23,42,.08);
  --shadow-2:0 16px 50px rgba(15,23,42,.12);
  --focus:0 0 0 3px rgba(31,111,235,.22);
}

*{ box-sizing:border-box; }
html, body{ overflow-x:hidden; }
body{
  margin:0;
  min-height:100vh;
  font-family:ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, "Helvetica Neue", Arial, "Noto Sans", "Liberation Sans", sans-serif;
  color:var(--text);
  background:linear-gradient(180deg, #ffffff 0%, #ffffff 40%, var(--bg-soft) 100%);
}
a{ color:inherit; text-decoration:none; }
::selection{ background:rgba(31,111,235,.18); }
@media (prefers-reduced-motion: reduce){ *{ scroll-behavior:auto !important; transition:none !important; animation:none !important; } }

.page-shell{ max-width:1200px; margin:0 auto; padding:18px 16px 44px; }

/* ========== HERO ========== */
.hero-v2{ display:grid; grid-template-columns:minmax(0, 1.15fr) minmax(0, .85fr); gap:28px; align-items:center; padding:18px 0 6px; }
.hero-title{ font-size:clamp(2.15rem, 3.6vw, 3.15rem); letter-spacing:-.03em; line-height:1.05; margin:0 0 12px; }
.accent-word{ color:var(--accent); text-shadow:0 10px 24px rgba(31,111,235,.20); }
.hero-desc{ margin:0; font-size:1rem; line-height:1.7; color:var(--text-muted); max-width:640px; }
.hero-points{ margin-top:16px; display:grid; grid-template-columns:repeat(2, minmax(0, 1fr)); gap:10px 18px; max-width:720px; }
.point{ display:flex; align-items:center; gap:10px; color:var(--text-soft); font-size:.92rem; }
.dot{ width:22px; height:22px; border-radius:999px; display:grid; place-items:center; font-weight:900; color:#fff; background:var(--accent); box-shadow:0 10px 20px rgba(31,111,235,.18); }
.hero-cta{ margin-top:18px; display:flex; gap:12px; flex-wrap:wrap; }

.hero-right{ justify-self:end; width:100%; display:flex; justify-content:flex-end; }
.logo-card{ width:min(560px, 100%); border-radius:22px; background:rgba(255,255,255,.88); border:1px solid rgba(15,23,42,.10); box-shadow:0 18px 55px rgba(15,23,42,.12); display:flex; flex-direction:column; align-items:center; justify-content:flex-start; position:relative; overflow:hidden; padding:18px 16px 16px; gap:12px; }
.logo-card::before{ content:""; position:absolute; inset:-2px; background:radial-gradient(520px 240px at 20% 20%, rgba(31,111,235,.16), transparent 55%), radial-gradient(520px 240px at 80% 80%, rgba(31,111,235,.10), transparent 60%); pointer-events:none; }
.logo-top{ width:100%; display:flex; justify-content:center; align-items:center; padding-top:6px; position:relative; z-index:1; }
.logo-card-img{ width:min(300px, 70%); height:auto; filter:drop-shadow(0 18px 34px rgba(15,23,42,.14)); }
.network-visual{ width:100%; position:relative; z-index:1; border-radius:18px; overflow:hidden; isolation:isolate; transform:translateZ(0); animation:floatCard 4.8s ease-in-out infinite; }
@keyframes floatCard{ 0%,100%{ transform:translateY(0); } 50%{ transform:translateY(-6px); } }
.network-img{ width:100%; height:auto; display:block; border-radius:18px; filter:drop-shadow(0 18px 40px rgba(15,23,42,.10)); }
.network-visual::after{ content:""; position:absolute; inset:-20%; background:radial-gradient(closest-side at 20% 30%, rgba(43,127,255,.18), transparent 60%), radial-gradient(closest-side at 75% 65%, rgba(31,111,235,.14), transparent 62%), linear-gradient(115deg, transparent 0%, rgba(255,255,255,.08) 40%, transparent 80%); mix-blend-mode:screen; opacity:.9; transform:translateX(-18%); animation:shimmerMove 5.5s ease-in-out infinite; pointer-events:none; z-index:2; }
@keyframes shimmerMove{ 0%,100%{ transform:translateX(-18%) translateY(0) rotate(0deg); } 50%{ transform:translateX(10%) translateY(-2%) rotate(2deg); } }
.node{ position:absolute; width:10px; height:10px; border-radius:999px; background:rgba(31,111,235,.95); box-shadow:0 0 0 0 rgba(31,111,235,.0); z-index:3; }
.node::before{ content:""; position:absolute; inset:-10px; border-radius:999px; border:2px solid rgba(31,111,235,.32); opacity:0; transform:scale(.6); animation:ping 1.9s ease-out infinite; }
.node::after{ content:""; position:absolute; inset:-20px; border-radius:999px; border:2px solid rgba(43,127,255,.18); opacity:0; transform:scale(.6); animation:ping 1.9s ease-out infinite .35s; }
@keyframes ping{ 0%{ opacity:0; transform:scale(.55); } 18%{ opacity:.75; } 100%{ opacity:0; transform:scale(1.6); } }
.n-kantor{ left:14%; top:54%; animation:nodeGlow 2.4s ease-in-out infinite; }
.n-umkm{ left:30%; top:70%; animation:nodeGlow 2.6s ease-in-out infinite .15s; }
.n-hotel{ left:50%; top:56%; animation:nodeGlow 2.8s ease-in-out infinite .25s; }
.n-resto{ left:66%; top:73%; animation:nodeGlow 2.7s ease-in-out infinite .20s; }
.n-perusahaan{ left:84%; top:55%; animation:nodeGlow 2.5s ease-in-out infinite .10s; }
@keyframes nodeGlow{ 0%,100%{ filter:brightness(1); } 50%{ filter:brightness(1.18); } }

/* ========== TABS + SECTION ========== */
.tabs{ display:flex; flex-wrap:wrap; gap:10px; margin:18px 0 18px; justify-content:center; }
.tab-btn{ border-radius:999px; padding:9px 14px; font-size:.82rem; border:1px solid rgba(15,23,42,.12); background:#fff; color:var(--text-muted); cursor:pointer; display:inline-flex; align-items:center; gap:8px; transition:transform .15s ease, background .15s ease, border-color .15s ease, color .15s ease; }
.tab-btn:hover{ transform:translateY(-1px); background:var(--bg-soft); border-color:var(--border-strong); color:var(--text); }
.tab-btn:focus{ outline:none; box-shadow:var(--focus); }
.tab-btn.active{ background:var(--accent); border-color:var(--accent); color:#fff; font-weight:800; }
.section{ border-radius:var(--radius-xl); padding:16px 14px 18px; background:rgba(255,255,255,.90); border:1px solid var(--border); box-shadow:var(--shadow-1); margin-bottom:18px; }
.section-head{ display:flex; justify-content:space-between; align-items:flex-end; gap:12px; margin-bottom:14px; }
.section-title{ font-size:1.04rem; font-weight:800; letter-spacing:-.01em; }
.section-sub{ font-size:.84rem; color:var(--text-muted); line-height:1.4; }
.plain-body{ color:#111827; line-height:1.7; }

/* ========== GRID + CARD ========== */
.pkg-grid{ display:grid; gap:14px; grid-template-columns:repeat(auto-fit, minmax(265px, 1fr)); justify-content:stretch; }
.pkg-grid.single{ justify-content:center; }
.pkg-grid.single .paket-card{ max-width:540px; width:100%; }
.paket-card{ position:relative; overflow:hidden; border-radius:var(--radius-lg); background:var(--card); border:1px solid var(--border); padding:14px; box-shadow:var(--shadow-1); display:flex; flex-direction:column; gap:10px; transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease; }
.paket-card:hover{ transform:translateY(-2px); border-color:var(--border-strong); box-shadow:var(--shadow-2); }
.card-inner{ position:relative; z-index:1; display:flex; flex-direction:column; gap:10px; height:100%; }
.card-header{ display:flex; align-items:center; gap:16px; }
.card-header-left{ display:flex; align-items:center; }
.card-header-right{ flex:1; display:flex; flex-direction:column; gap:6px; align-items:flex-end; }
.paket-title{ font-size:1rem; margin:0; font-weight:800; letter-spacing:-.01em; text-align:right; color:var(--text); }
.price-block{ text-align:right; }
.price-main{ font-size:1.12rem; font-weight:900; line-height:1.05; letter-spacing:-.01em; }
.price-note{ font-size:.74rem; color:var(--text-muted); }
.benefit-list{ list-style:none; padding:0; margin:6px 0 0; font-size:.84rem; color:var(--text-muted); text-align:right; width:100%; line-height:1.45; }
.benefit-list li{ margin-bottom:3px; }
.ring{ width:92px; height:92px; border-radius:999px; display:flex; align-items:center; justify-content:center; position:relative; --angle:0deg; background:conic-gradient(var(--accent) var(--angle), rgba(15,23,42,.10) 0deg); transition:--angle .9s ease-out; box-shadow:0 12px 26px rgba(15,23,42,.10); }
.ring::after{ content:""; position:absolute; inset:14px; background:#fff; border-radius:999px; border:1px solid rgba(15,23,42,.08); }
.ring span{ position:relative; z-index:1; font-size:19px; font-weight:900; letter-spacing:-.02em; color:var(--text); }

/* ========== BUTTONS ========== */
.card-actions{ display:grid; grid-template-columns:1fr 1.15fr; gap:10px; margin-top:2px; padding-top:10px; border-top:1px solid rgba(15,23,42,.06); }
.card-actions .btn{ width:100%; min-width:0; padding:10px 12px; font-size:.78rem; text-align:center; }
.card-actions [data-quote]{ white-space:normal; line-height:1.2; }
.btn{ border-radius:999px; padding:10px 14px; font-size:.82rem; border:none; cursor:pointer; display:inline-flex; align-items:center; justify-content:center; gap:8px; white-space:nowrap; transition:transform .15s ease, filter .15s ease, background .15s ease, border-color .15s ease, opacity .15s ease; font-family:inherit; }
.btn:focus{ outline:none; box-shadow:var(--focus); }
.btn:disabled{ opacity:.65; cursor:not-allowed; transform:none !important; }
.btn-primary{ background:linear-gradient(180deg, var(--accent-2) 0%, var(--accent) 100%); color:#fff; font-weight:900; }
.btn-primary:hover{ filter:brightness(1.04); transform:translateY(-1px); }
.btn-ghost{ background:#fff; border:1px solid var(--border); color:var(--text); padding-inline:14px; }
.btn-ghost:hover{ background:var(--bg-soft); border-color:var(--border-strong); transform:translateY(-1px); }

/* ========== MODAL ========== */
.modal-overlay{ position:fixed; inset:0; background:rgba(15,23,42,.50); backdrop-filter:blur(10px); display:none; align-items:center; justify-content:center; z-index:80; padding:14px; }
.modal-overlay.show{ display:flex; }
.modal-card{ max-width:460px; width:100%; background:#fff; border-radius:22px; border:1px solid var(--border); box-shadow:0 24px 70px rgba(15,23,42,.22); padding:16px 16px 14px; color:var(--text); font-size:.90rem; }
.modal-header{ display:flex; justify-content:space-between; gap:12px; align-items:flex-start; margin-bottom:10px; }
.modal-title{ font-size:1.04rem; font-weight:900; letter-spacing:-.01em; }
.modal-close{ border:none; background:#fff; border:1px solid var(--border); color:var(--text); width:34px; height:34px; border-radius:10px; font-size:1.2rem; cursor:pointer; display:grid; place-items:center; flex:0 0 auto; }
.modal-close:hover{ background:var(--bg-soft); border-color:var(--border-strong); }
.modal-scheme-tabs{ display:flex; flex-wrap:wrap; gap:8px; margin-bottom:12px; }
.modal-section-label{ font-size:.80rem; color:var(--text-muted); margin-bottom:6px; }
.modal-table{ width:100%; border-collapse:collapse; font-size:.84rem; margin-bottom:8px; }
.modal-table td{ padding:4px 0; }
.modal-table td:first-child{ color:var(--text-muted); }
.modal-table td:last-child{ text-align:right; font-variant-numeric:tabular-nums; color:var(--text); }
.modal-footer-text{ margin-top:10px; font-size:.84rem; color:var(--text-muted); line-height:1.55; }
.modal-footer-text strong{ color:var(--text); }
.modal-footer-actions{ margin-top:10px; display:flex; gap:10px; justify-content:flex-end; flex-wrap:wrap; }

/* ========== MODAL FORM PENAWARAN ========== */
.quote-modal-overlay{ align-items:flex-start; overflow-y:auto; }
.quote-modal-card{ max-width:780px; margin:22px auto; max-height:none; }
.quote-form{ display:flex; flex-direction:column; gap:14px; }
.quote-form-section{ border:1px solid rgba(15,23,42,.08); border-radius:16px; background:#fff; padding:14px; }
.quote-form-title{ font-weight:900; font-size:.94rem; margin-bottom:12px; color:var(--text); letter-spacing:-.01em; }
.form-grid{ display:grid; grid-template-columns:repeat(2, minmax(0, 1fr)); gap:12px; }
.form-field{ display:flex; flex-direction:column; gap:6px; margin-bottom:12px; }
.form-field:last-child{ margin-bottom:0; }
.form-field span{ font-size:.80rem; font-weight:800; color:#334155; }
.form-field b{ color:#dc2626; }
.form-field input, .form-field textarea, .form-field select{ width:100%; border:1px solid rgba(15,23,42,.14); background:#fff; border-radius:12px; padding:10px 11px; font-size:.88rem; color:var(--text); font-family:inherit; outline:none; transition:border-color .15s ease, box-shadow .15s ease, background .15s ease; }
.form-field textarea{ resize:vertical; min-height:82px; }
.form-field input:focus, .form-field textarea:focus, .form-field select:focus{ border-color:rgba(31,111,235,.62); box-shadow:var(--focus); }
.form-field input[readonly]{ background:#f8fafc; color:#475569; cursor:not-allowed; }
.quote-consent{ display:flex; gap:10px; align-items:flex-start; font-size:.82rem; line-height:1.45; color:var(--text-muted); }
.quote-consent input{ margin-top:3px; }
.quote-form-status{ display:none; border-radius:12px; padding:10px 12px; font-size:.86rem; line-height:1.5; }
.quote-form-status.success{ display:block; background:rgba(22,163,74,.10); color:#166534; border:1px solid rgba(22,163,74,.22); }
.quote-form-status.error{ display:block; background:rgba(220,38,38,.10); color:#991b1b; border:1px solid rgba(220,38,38,.22); }

/* ========== INFO SECTION CARD ========== */
.info-section{ display:grid; gap:14px; margin-bottom:24px; }
.info-card{ display:grid; grid-template-columns:42px minmax(0, 1fr); gap:14px; padding:18px; border-radius:var(--radius-xl); background:rgba(255,255,255,.94); border:1px solid var(--border); box-shadow:var(--shadow-1); }
.info-card-icon{ width:42px; height:42px; border-radius:999px; display:grid; place-items:center; background:rgba(31,111,235,.10); color:var(--accent); font-weight:900; font-size:1rem; border:1px solid rgba(31,111,235,.18); }
.info-card-body{ min-width:0; }
.info-card .section-title{ margin-bottom:6px; }
.info-card .plain-body{ max-width:980px; }
.support-card{ background:radial-gradient(520px 160px at 15% 0%, rgba(31,111,235,.10), transparent 60%), rgba(255,255,255,.96); }
.support-list{ margin-top:14px; display:grid; grid-template-columns:repeat(2, minmax(0, 1fr)); gap:10px; }
.support-list div{ padding:11px 12px; border-radius:14px; background:#fff; border:1px solid rgba(15,23,42,.08); display:flex; justify-content:space-between; gap:12px; align-items:center; }
.support-list span{ color:var(--text-muted); font-size:.84rem; }
.support-list strong{ color:var(--text); font-size:.92rem; text-align:right; word-break:break-word; }

/* ========== FOOTER ========== */
.paket-loading{ text-align:center; padding:2rem 1rem; font-size:.98rem; color:var(--text-muted); }
.site-footer{ border-top:1px solid rgba(15,23,42,.08); margin-top:22px; padding:18px 0 6px; color:var(--text-muted); font-size:.86rem; }
.footer-card{ width:100%; }
.footer-brand h2{ color:var(--text); margin:0 0 6px; font-size:1.15rem; }
.footer-brand p{ line-height:1.72; color:var(--text-muted); max-width:980px; }
.footer-links{ display:flex; flex-wrap:wrap; gap:12px; margin:8px 0; }
.footer-links a{ color:var(--accent); font-weight:700; }
.footer-copy{ color:var(--text-muted); font-size:.84rem; }

/* ========== RESPONSIVE ========== */
@media (max-width:900px){
  .hero-v2{ grid-template-columns:minmax(0,1fr); }
  .hero-right{ justify-self:stretch; justify-content:flex-start; }
  .logo-card{ width:100%; margin-top:14px; }
  .hero-points{ grid-template-columns:repeat(2, minmax(0,1fr)); }
  .pkg-grid{ grid-template-columns:repeat(2, minmax(0, 1fr)); }
}
@media (max-width:760px){
  .quote-modal-card{ margin:10px auto; border-radius:18px; }
  .form-grid{ grid-template-columns:minmax(0, 1fr); }
  .modal-footer-actions{ justify-content:stretch; }
  .modal-footer-actions .btn{ flex:1; }
  .info-card{ grid-template-columns:1fr; }
  .support-list{ grid-template-columns:1fr; }
  .support-list div{ align-items:flex-start; flex-direction:column; gap:4px; }
  .support-list strong{ text-align:left; }
}
@media (max-width:640px){
  .hero-points{ grid-template-columns:minmax(0,1fr); }
  .pkg-grid{ grid-template-columns:minmax(0, 1fr); }
  .card-header{ gap:12px; }
  .ring{ width:82px; height:82px; }
  .card-actions{ grid-template-columns:1fr; }
  .card-actions .btn{ width:100%; font-size:.82rem; }
  .modal-card{ padding:14px; }
}
