@import url('https://fonts.googleapis.com/css2?family=Pacifico&display=swap');

html {
  scroll-behavior: smooth;
}

* {
  scrollbar-width: thin;
  scrollbar-color: #1e40af #f1f1f1;
}

::-webkit-scrollbar {
  width: 12px;
}

::-webkit-scrollbar-track {
  background: #f1f1f1;
  border-radius: 6px;
}

::-webkit-scrollbar-thumb {
  background-color: #1e40af;
  border-radius: 6px;
  border: 3px solid #f1f1f1;
}

::-webkit-scrollbar-thumb:hover {
  background-color: #2563eb;
}

/* ================= DARK MODE FULL ================= */

/* Global */
.dark * {
  background-color: transparent;
  color: inherit;
  border-color: #4b5563;
  transition: background-color 0.3s ease, color 0.3s ease, border-color 0.3s ease;
}

.dark body { 
  background-color: #111827 !important; 
  color: #f9fafb !important; 
}

/* Sidebar & Navbar */
.dark #sidebar { 
  background: linear-gradient(180deg, #111827, #1f2937); 
}
.dark #navbar { 
  background-color: #1f2937 !important; 
}

/* Link */
.dark .nav-link { color: #d1d5db !important; }
.dark .nav-link.active { background-color: rgba(255,255,255,0.2) !important; }

/* Container */
.dark section,
.dark footer,
.dark header,
.dark main,
.dark article,
.dark aside,
.dark .card,
.dark .modal,
.dark .hover-card,
.dark .bg-white,
.dark .bg-gray-50,
.dark .bg-gray-100,
.dark .bg-blue-50,
.dark .tab-content,
.dark .qualification-item .content {
  background-color: #1f2937 !important; 
  color: #f9fafb !important; 
}

/* Typography */
.dark h1, 
.dark h2, 
.dark h3, 
.dark h4, 
.dark h5, 
.dark h6 { color: #f9fafb !important; }

.dark p, 
.dark span, 
.dark label, 
.dark li, 
.dark a, 
.dark td,
.dark th { color: #d1d5db !important; }

/* Form */
.dark input,
.dark select,
.dark textarea,
.dark button {
  background-color: #374151 !important; 
  color: #f9fafb !important; 
  border-color: #4b5563 !important; 
}

.dark input:focus,
.dark select:focus,
.dark textarea:focus {
  border-color: #60a5fa !important; 
  outline: none; 
}

/* Progress bar & buttons */
.dark #progressBar { background-color: #facc15 !important; }
.dark #scrollTopBtn { background-color: #2563eb !important; color: #fff !important; }

/* Grid Items */
.dark .android-card,
.dark .office-card,
.dark .content-card,
.dark .video-card,
.dark .analytics-card,
.dark .diagram-card,
.dark .uiux-card,
.dark .game-card,
.dark .network-card,
.dark .reverse-card,
.dark .software-card,
.dark .frontend-card,
.dark .backend-card,
.dark .fullstack-card,
.dark .build-card,
.dark .web-servers-card,
.dark .database-card,
.dark .ciCd-card,
.dark .testing-card,
.dark .tools-card {
  background: linear-gradient(to bottom right, #1f2937, #111827) !important;
  color: #f9fafb !important;
}
.dark .android-card,
.dark .office-card,
.dark .content-card,
.dark .video-card,
.dark .analytics-card,
.dark .diagram-card,
.dark .uiux-card,
.dark .game-card,
.dark .network-card,
.dark .reverse-card,
.dark .software-card,
.dark .frontend-card,
.dark .backend-card,
.dark .fullstack-card,
.dark .build-card,
.dark .web-servers-card,
.dark .database-card,
.dark .ciCd-card,
.dark .testing-card,
.dark .tools-card span {
  color: #d1d5db !important;
}

/* Certification */
.dark .cert-item {
  background-color: #1f2937 !important;
  color: #f9fafb !important;
  box-shadow: 0 6px 20px rgba(0,0,0,0.4) !important;
}
.dark .cert-item h3 { color: #f9fafb !important; }
.dark .cert-item p { color: #d1d5db !important; }
.dark .cert-item span {
  background-color: rgba(96, 165, 250, 0.2) !important;
  color: #93c5fd !important;
}
.dark .cert-item a {
  background-color: #2563eb !important;
  color: #fff !important;
}
.dark .cert-item a:hover {
  background-color: #1d4ed8 !important;
}

/* Timeline */
.dark .qualification-item .content { background: #374151 !important; color: #f9fafb !important; }
.dark .qualification-item.left .content::before { border-color: transparent transparent transparent #374151; }
.dark .qualification-item.right .content::before { border-color: transparent #374151 transparent transparent; }

/* Tabs */
.dark .tab-btn {
  border-color: #60a5fa;
  color: #60a5fa;
  background: transparent;
}
.dark .tab-btn.active,
.dark .tab-btn:hover {
  background: #60a5fa;
  color: #111827;
}

/* Testimoni */
.dark .bg-white\/70 {
  background-color: rgba(31,41,55,0.7) !important;
  color: #f9fafb !important;
  border-left-color: #60a5fa !important;
}

/* Nama client */
.dark h5.text-blue-700 {
  color: #60a5fa !important;
}

/* Position & company */
.dark p.text-gray-500 {
  color: #d1d5db !important;
}

/* Project text */
.dark p.text-gray-400 {
  color: #9ca3af !important;
}

/* Experience (main text) */
.dark .text-gray-700 {
  color: #f3f4f6 !important;
}

/* Icon quote warna */
.dark svg.text-blue-400 {
  color: #60a5fa !important;
}

/* Avatar border */
.dark img.border-blue-400 {
  border-color: #60a5fa !important;
}

/* Table */
.dark table { background-color: #1f2937; border-color: #374151; }
.dark th { background-color: #374151; }
.dark tr:hover { background-color: #2d3748; }

/* Scrollbar */
.dark * { scrollbar-color: #60a5fa #1f2937; }
.dark ::-webkit-scrollbar-track { background: #1f2937; }
.dark ::-webkit-scrollbar-thumb { background-color: #60a5fa; border: 3px solid #1f2937; }
.dark ::-webkit-scrollbar-thumb:hover { background-color: #93c5fd; }

/* SweetAlert */
.dark .swal2-popup {
  background: #1f2937 !important;
  color: #f9fafb !important;
  border-radius: 0.75rem;
}
.dark .swal2-title { color: #f9fafb !important; }
.dark .swal2-html-container { color: #d1d5db !important; }
.dark .swal2-popup input,
.dark .swal2-popup textarea,
.dark .swal2-popup select {
  background-color: #374151 !important;
  border: 1px solid #4b5563 !important;
  color: #f9fafb !important;
}
.dark .swal2-popup input:focus,
.dark .swal2-popup textarea:focus,
.dark .swal2-popup select:focus {
  border-color: #60a5fa !important;
  outline: none !important;
}
.dark .swal2-popup label { color: #d1d5db !important; }
.dark .swal2-styled {
  background: #2563eb !important;
  color: #fff !important;
  border: none !important;
}
.dark .swal2-styled:hover { background: #1d4ed8 !important; }

/* Drop zone */
.dark #dropZone {
  border-color: #4b5563 !important;
  background-color: #374151 !important;
  color: #d1d5db !important;
}
.dark #dropZone:hover {
  border-color: #60a5fa !important;
  background-color: #1f2937 !important;
  color: #f9fafb !important;
}
.dark #photoPath { color: #9ca3af !important; }

/* CKEditor */
.dark .ck.ck-editor__main > .ck-editor__editable {
  background-color: #1f2937 !important;
  color: #f9fafb !important;
  border-color: #4b5563 !important;
}
.dark .ck.ck-editor__main > .ck-editor__editable:focus {
  border-color: #60a5fa !important;
  box-shadow: 0 0 0 1px #60a5fa !important;
}
.dark .ck.ck-toolbar {
  background-color: #111827 !important;
  border-color: #374151 !important;
}
.dark .ck.ck-toolbar .ck-button { color: #d1d5db !important; }
.dark .ck.ck-toolbar .ck-button:hover,
.dark .ck.ck-toolbar .ck-button.ck-on {
  background: #2563eb !important;
  color: #fff !important;
}
.dark .ck.ck-dropdown__panel {
  background-color: #1f2937 !important;
  border-color: #374151 !important;
  color: #f9fafb !important;
}
.dark .ck.ck-list__item { color: #f9fafb !important; }
.dark .ck.ck-list__item:hover {
  background-color: #2563eb !important;
  color: #fff !important;
}

/* ================================================== */

#mainContent {
  transition: margin-left 0.3s ease;
}

.sidebar-collapsed {
  width: 80px !important;
}

.sidebar-collapsed ul li a span {
  display: none;
}

.sidebar-collapsed img {
  width: 40px;
  height: 40px;
}

.sidebar-collapsed h3,
.sidebar-collapsed p {
  display: none;
}

@media (min-width: 768px) {
  #mainContent {
    margin-left: 16rem;
  }

  #mainContent.expanded {
    margin-left: 80px;
  }
}
    
/* Sidebar Styling */
#sidebar {
  background: linear-gradient(180deg, #1d4ed8, #1e40af);
  color: white;
}

#sidebar .nav-link {
  color: #e5e7eb;
  border-radius: 8px;
  transition: all 0.3s ease;
}

#sidebar .nav-link:hover {
  background-color: rgba(255, 255, 255, 0.15);
  transform: translateX(4px);
}

#sidebar .nav-link.active {
  background-color: rgba(255, 255, 255, 0.3);
  color: white !important;
}

.menu-list li {
  border-bottom: 1px solid #ddd;
}

.menu-list li:last-child {
  border-bottom: none;
}

.menu-list a {
  display: flex;
  align-items: center;
  gap: 8px;
  text-decoration: none;
  color: #333;
}

.menu-list a:hover {
  background: #f5f5f5; /* efek hover */
}

.nav-link {
  transition: all 0.3s ease;
  border-left: 5px solid transparent; /* default border kiri transparan */
}

.nav-link.active {
  border-left-color: #facc15; /* kuning Tailwind yellow-400 */
  background-color: #fefce8;   /* opsional background kuning muda */
}

.nav-link:hover {
  border-left-color: #facc15; /* kuning saat hover */
  background-color: #fefce8;   /* opsional */
}

#progressBar {
  transition: width 0.1s linear;
}

/* Card hover effect */
.hover-card {
  transition: all 0.3s ease;
}

.hover-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 6px 20px rgba(0, 0, 0, 0.15);
}

.scrolled {
  background-color: #1e40af !important;
  transition: background-color 0.3s ease;
}

.scrolled h1 {
  color: white !important;
}

.hero_intro{
  font-family: 'Pacifico', cursive;
}

.blob {
  border-radius: 30% 70% 70% 30% / 30% 30% 70% 70% ;
}

#about img {
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}

#about img:hover {
  transform: scale(1.05);
  box-shadow: 0 10px 28px rgba(0,0,0,0.25);
}

#about .btn {
  padding: 10px 22px;
  border-radius: 8px;
  font-weight: 600;
}

#about .grid div h3 {
  line-height: 1.2;
}

.tab-btn {
  padding: 0.5rem 1.5rem;
  margin: 0 0.5rem;
  font-weight: 600;
  border-radius: 9999px;
  border: 2px solid #1d4ed8;
  color: #1d4ed8;
  background: #fff;
  transition: all 0.3s ease;
}

.tab-btn.active,
.tab-btn:hover {
  background: #1d4ed8;
  color: #fff;
}

.tab-content {
  display: none;
}

.tab-content.active {
  display: block;
}

.qualification-timeline {
  position: relative;
  margin: 2rem 0;
  padding: 1rem 0;
}

.qualification-timeline::before {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  left: 50%;
  width: 4px;
  background: linear-gradient(to bottom, #1d4ed8, #2563eb, #3b82f6);
  transform: translateX(-50%);
  border-radius: 4px;
  z-index: 0;
}

.qualification-item {
  position: relative;
  width: 50%;
  padding: 1rem 2rem;
}

.qualification-item.left {
  left: 0;
  text-align: left;
}

.qualification-item.right {
  left: 50%;
  text-align: right;
}

.qualification-item::before {
  content: "";
  position: absolute;
  top: 1.25rem;
  width: 18px;
  height: 18px;
  border-radius: 50%;
  background: #1d4ed8;
  border: 4px solid #fff;
  z-index: 2;
}

.qualification-item.left::before {
  right: -9px;
}

.qualification-item.right::before {
  left: -9px;
}

.qualification-item .content {
  background: #f9fafb;
  padding: 1rem 1.5rem;
  border-radius: 0.75rem;
  box-shadow: 0 6px 20px rgba(0,0,0,0.15);
  position: relative;
  z-index: 1;
  transition: all 0.3s ease;
}

.qualification-item .content:hover {
  transform: translateY(-6px) scale(1.02);
  box-shadow: 0 10px 25px rgba(29, 78, 216, 0.25);
}

.qualification-item.left .content::before,
.qualification-item.right .content::before {
  content: "";
  position: absolute;
  top: 1.2rem;
  width: 0;
  height: 0;
  border-style: solid;
}

.qualification-item.left .content::before {
  right: -15px;
  border-width: 8px 0 8px 15px;
  border-color: transparent transparent transparent #f9fafb;
}

.qualification-item.right .content::before {
  left: -15px;
  border-width: 8px 15px 8px 0;
  border-color: transparent #f9fafb transparent transparent;
}

.qualification-item .content span {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  font-weight: 500;
}

.qualification-item .content span i {
  font-size: 0.9rem;
}

@media (max-width: 768px) {
  .qualification-item,
  .qualification-item.left,
  .qualification-item.right {
    width: 100%;
    left: 0;
    text-align: left;
    margin-bottom: 2rem;
  }

  .qualification-timeline::before {
    left: 20px;
  }

  .qualification-item::before {
    left: 12px;
  }

  .qualification-item .content {
    margin-left: 3rem;
  }

  .qualification-item.left .content::before,
  .qualification-item.right .content::before {
    left: -15px;
    border-width: 8px 15px 8px 0;
    border-color: transparent #f9fafb transparent transparent;
  }
}