html { scroll-behavior: smooth; overflow-x: hidden; }
body { font-family: 'Inter', sans-serif; overflow-x: hidden; }
.font-display { font-family: 'Plus Jakarta Sans', sans-serif; }
.grid-bg {
  background-image:
    linear-gradient(rgba(34,211,238,0.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(34,211,238,0.04) 1px, transparent 1px);
  background-size: 48px 48px;
}
.hero-gradient {
  background: linear-gradient(145deg, #07111F 0%, #0c1f3d 45%, #07111F 100%);
}
.glass-nav {
  background: rgba(255,255,255,0.82);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
}
.glass-nav.dark-nav {
  background: rgba(7,17,31,0.85);
  border-color: rgba(255,255,255,0.08);
}
.glass-nav.dark-nav .nav-link { color: rgba(255,255,255,0.85); }
.glass-nav.dark-nav .nav-link:hover { color: #22D3EE; }
.glass-nav.dark-nav .brand-text { color: #fff; }
.glass-nav.light-page .nav-link { color: #64748B; }
.text-mask { overflow: hidden; }
.text-mask-inner { display: inline-block; transform: translateY(110%); }
.solution-card { transition: border-color 0.35s ease, box-shadow 0.35s ease, transform 0.35s ease; }
.solution-card:hover {
  border-color: rgba(34,211,238,0.45);
  box-shadow: 0 0 0 1px rgba(34,211,238,0.15), 0 20px 40px -20px rgba(21,94,239,0.25);
  transform: translateY(-2px);
}
.logo-card { transition: border-color 0.35s ease, box-shadow 0.35s ease, transform 0.35s ease; }
.logo-card:hover {
  border-color: rgba(34,211,238,0.45);
  box-shadow: 0 0 0 1px rgba(34,211,238,0.15), 0 20px 40px -20px rgba(21,94,239,0.25);
  transform: translateY(-2px);
}
.btn-lift { transition: transform 0.25s ease, box-shadow 0.25s ease; }
.btn-lift:hover { transform: translateY(-2px); box-shadow: 0 12px 24px -8px rgba(21,94,239,0.35); }
.dash-node { animation: pulse-node 3s ease-in-out infinite; }
@keyframes pulse-node {
  0%, 100% { opacity: 0.6; transform: scale(1); }
  50% { opacity: 1; transform: scale(1.15); }
}
.timeline-fill { transform-origin: left center; transform: scaleX(0); }
.cap-card .cap-line { transform: scaleX(0); transform-origin: left; transition: transform 0.5s ease; }
.cap-card:hover .cap-line { transform: scaleX(1); }
.mobile-menu { transform: translateY(-100%); transition: transform 0.45s cubic-bezier(0.22,1,0.36,1); pointer-events: none; visibility: hidden; }
.mobile-menu.open { transform: translateY(0); pointer-events: auto; visibility: visible; }
.modal-overlay { opacity: 0; visibility: hidden; transition: opacity 0.35s ease, visibility 0.35s ease; }
.modal-overlay.active { opacity: 1; visibility: visible; }
.modal-card { transform: translateY(24px) scale(0.97); transition: transform 0.4s cubic-bezier(0.22,1,0.36,1); }
.modal-overlay.active .modal-card { transform: translateY(0) scale(1); }
.float-wa { z-index: 90; }
.brand-mark { width: 28px; height: 28px; position: relative; }
.brand-mark span { position: absolute; border-radius: 3px; }
.brand-mark .m1 { width: 12px; height: 12px; background: #22D3EE; top: 2px; left: 2px; }
.brand-mark .m2 { width: 12px; height: 12px; background: #155EEF; bottom: 2px; right: 2px; opacity: 0.85; }
.brand-mark .m3 { width: 6px; height: 6px; background: #fff; top: 50%; left: 50%; transform: translate(-50%,-50%); border-radius: 50%; }
input:focus, select:focus, textarea:focus {
  outline: none; border-color: #155EEF; box-shadow: 0 0 0 3px rgba(21,94,239,0.15);
}
.page-hero { background: linear-gradient(145deg, #07111F 0%, #0c1f3d 45%, #07111F 100%); }
.logo-placeholder {
  background: linear-gradient(135deg, #F8FAFC 0%, #E2E8F0 100%);
}
.logo-img {
  filter: none;
  max-width: 100%;
}

/* Indicom company logo — indicom.png (transparent, ~4.1:1) */
.indicom-logo-link,
.indicom-logo-wrap {
  display: inline-flex;
  align-items: center;
  flex-shrink: 0;
  line-height: 0;
}
.indicom-logo {
  display: block;
  width: var(--indicom-w, 10.5rem);
  height: auto;
  max-width: 100%;
  object-fit: contain;
  object-position: left center;
}
.indicom-logo--navbar { --indicom-w: 10.5rem; }
@media (min-width: 640px) {
  .indicom-logo--navbar { --indicom-w: 11.75rem; }
}
@media (min-width: 1024px) {
  .indicom-logo--navbar { --indicom-w: 12.5rem; }
}
.indicom-logo--footer { --indicom-w: 13rem; }
footer .indicom-logo-link--footer {
  margin-bottom: 1rem;
  padding: 0.5rem 0.85rem;
  background: #fff;
  border-radius: 0.625rem;
}
.indicom-logo--admin { --indicom-w: 7.25rem; }
.indicom-logo-wrap--admin {
  padding: 0.35rem 0.55rem;
  background: #fff;
  border-radius: 0.5rem;
  flex-shrink: 0;
}
.indicom-logo--login {
  --indicom-w: 13rem;
  margin: 0 auto 1.25rem;
}
/* Navbar gelap (hero scroll) — logo tetap terbaca */
.glass-nav.dark-nav .indicom-logo-link--navbar {
  padding: 0.35rem 0.65rem;
  background: #fff;
  border-radius: 0.5rem;
}

/* Admin Panel */
.admin-sidebar {
  background: linear-gradient(180deg, #07111F 0%, #0c1f3d 100%);
  border-right: 1px solid rgba(255,255,255,0.06);
}
.admin-topbar { background: rgba(255,255,255,0.92); backdrop-filter: blur(12px); }
.admin-nav-link {
  display: flex; align-items: center; gap: 0.75rem;
  padding: 0.65rem 0.85rem; border-radius: 0.75rem;
  color: rgba(255,255,255,0.72); font-size: 0.875rem; font-weight: 500;
  transition: background 0.2s, color 0.2s;
}
.admin-nav-link:hover { background: rgba(255,255,255,0.08); color: #fff; }
.admin-nav-link.active { background: rgba(21,94,239,0.25); color: #22D3EE; box-shadow: inset 0 0 0 1px rgba(34,211,238,0.15); }
.admin-nav-external { color: #22D3EE; }
.admin-page-header { display: flex; flex-wrap: wrap; align-items: flex-start; justify-content: space-between; gap: 1rem; margin-bottom: 1.5rem; }
.admin-page-title { font-family: 'Plus Jakarta Sans', sans-serif; font-weight: 700; font-size: 1.5rem; color: #07111F; }
.admin-page-desc { color: #64748B; font-size: 0.875rem; margin-top: 0.25rem; }
.admin-card { background: #fff; border: 1px solid #E2E8F0; border-radius: 1rem; box-shadow: 0 1px 3px rgba(7,17,31,0.04); }
.admin-stat-card { background: #fff; border: 1px solid #E2E8F0; border-radius: 1rem; padding: 1.25rem 1.5rem; }
.admin-stat-label { color: #64748B; font-size: 0.8125rem; }
.admin-stat-value { font-family: 'Plus Jakarta Sans', sans-serif; font-weight: 700; font-size: 2rem; color: #155EEF; margin-top: 0.35rem; }
.admin-btn-primary { display: inline-flex; align-items: center; padding: 0.65rem 1.25rem; background: #155EEF; color: #fff; font-weight: 600; font-size: 0.875rem; border-radius: 0.75rem; transition: background 0.2s; }
.admin-btn-primary:hover { background: #1d4ed8; }
.admin-btn-secondary { display: inline-flex; align-items: center; padding: 0.65rem 1.25rem; background: #fff; border: 1px solid #E2E8F0; color: #07111F; font-weight: 600; font-size: 0.875rem; border-radius: 0.75rem; transition: border-color 0.2s, color 0.2s; }
.admin-btn-secondary:hover { border-color: #155EEF; color: #155EEF; }
.admin-label { display: block; font-size: 0.875rem; font-weight: 500; color: #07111F; margin-bottom: 0.375rem; }
.admin-input { width: 100%; padding: 0.75rem 1rem; border: 1px solid #E2E8F0; border-radius: 0.75rem; font-size: 0.875rem; }
.admin-table { width: 100%; font-size: 0.875rem; }
.admin-table thead { background: #F8FAFC; }
.admin-table th { text-align: left; padding: 0.85rem 1rem; font-weight: 600; color: #64748B; font-size: 0.75rem; text-transform: uppercase; letter-spacing: 0.04em; }
.admin-table td { padding: 1rem; border-top: 1px solid #F1F5F9; vertical-align: middle; }
.admin-link { color: #155EEF; font-weight: 600; font-size: 0.8125rem; }
.admin-link:hover { text-decoration: underline; }
.admin-link-danger { color: #DC2626; font-weight: 600; font-size: 0.8125rem; }
.admin-link-danger:hover { text-decoration: underline; }
.admin-badge { display: inline-flex; padding: 0.2rem 0.65rem; border-radius: 9999px; font-size: 0.75rem; font-weight: 600; }
.admin-badge-success { background: #DCFCE7; color: #166534; }
.admin-badge-muted { background: #F1F5F9; color: #64748B; }
.admin-alert { margin-bottom: 1rem; padding: 0.85rem 1rem; border-radius: 0.75rem; font-size: 0.875rem; }
.admin-alert-success { background: #F0FDF4; border: 1px solid #BBF7D0; color: #166534; }
.admin-alert-error { background: #FEF2F2; border: 1px solid #FECACA; color: #991B1B; }
