/* =========================================================
   PREMIUM FUTURISTIC THEME (Bootstrap-friendly)
   - Clean, elegant, professional
   - Supports Light/Dark via data-theme
   - CLEANED + MOBILE FIXED (ADMIN + PUBLIC)
   ========================================================= */

/* =========================================================
   0) GLOBAL: anti overflow / base
   ========================================================= */
html, body { max-width: 100%; overflow-x: hidden; }
* { box-sizing: border-box; }

:root{
  --font: Inter, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;

  --radius: 18px;
  --radius-sm: 14px;
  --shadow: 0 18px 45px rgba(2,6,23,.18);
  --shadow-soft: 0 10px 26px rgba(2,6,23,.10);

  --primary: #4f46e5;
  --primary2:#06b6d4;

  /* LIGHT */
  --bg: #f5f7fb;
  --panel: rgba(255,255,255,.95);
  --border: rgba(15,23,42,.10);
  --text: rgba(15,23,42,.92);
  --muted: rgba(15,23,42,.60);

  --glass: rgba(255,255,255,.62);
  --glass-border: rgba(255,255,255,.30);

  --ring: 0 0 0 .22rem rgba(79,70,229,.16);
}

html[data-theme="dark"]{
  --bg: #070b16;
  --panel: rgba(255,255,255,.06);
  --border: rgba(255,255,255,.12);
  --text: rgba(255,255,255,.92);
  --muted: rgba(255,255,255,.62);
  --glass: rgba(255,255,255,.06);
  --glass-border: rgba(255,255,255,.14);
  --shadow: 0 22px 60px rgba(0,0,0,.35);
  --shadow-soft: 0 14px 34px rgba(0,0,0,.24);
  --ring: 0 0 0 .22rem rgba(99,102,241,.18);
}

body{
  font-family: var(--font);
  background: var(--bg);
  color: var(--text);
}

a{ text-decoration:none; }
a:hover{ text-decoration:none; }

/* Dark futuristic background */
html[data-theme="dark"] body{
  background:
    radial-gradient(1200px circle at 20% 10%, rgba(99,102,241,.20), transparent 55%),
    radial-gradient(900px circle at 80% 20%, rgba(6,182,212,.16), transparent 55%),
    linear-gradient(180deg, #070b16 0%, #0b1220 45%, #0f172a 100%);
}

/* =========================================================
   1) PANELS / GLASS
   ========================================================= */
.px-panel{
  background: var(--panel);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  box-shadow: var(--shadow-soft);
}
.px-glass{
  background: var(--glass);
  border: 1px solid var(--glass-border);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  backdrop-filter: blur(16px);
  position: relative;
  overflow: hidden;
}
.px-glass:before{
  content:"";
  position:absolute;
  inset:-2px;
  background: radial-gradient(900px circle at 20% 10%, rgba(79,70,229,.16), transparent 55%),
              radial-gradient(900px circle at 80% 20%, rgba(6,182,212,.12), transparent 55%);
  pointer-events:none;
  opacity: .55;
}
.px-glass > *{ position: relative; z-index: 1; }

.px-title{ font-weight: 900; letter-spacing: .2px; line-height: 1.15; }
.px-subtitle{ color: var(--muted); line-height: 1.35; }

/* =========================================================
   2) BUTTONS
   ========================================================= */
.btn{
  border-radius: var(--radius-sm);
  font-weight: 800;
  padding: .55rem .95rem;
  letter-spacing: .01em;
  transition: background-color .18s ease, border-color .18s ease, color .18s ease, box-shadow .18s ease, transform .18s ease;
}
.btn:active{ transform: translateY(1px); }

.btn-primary{
  border:none;
  background: linear-gradient(135deg, var(--primary), var(--primary2));
  box-shadow: 0 14px 28px rgba(79,70,229,.20);
}
.btn-primary:hover{ filter: brightness(1.03); }

.btn-outline-secondary{
  border-color: rgba(15,23,42,.18);
}
html[data-theme="dark"] .btn-outline-secondary{
  border-color: rgba(255,255,255,.18);
  color: rgba(255,255,255,.88);
}

.btn-outline-light{
  border-color: rgba(255,255,255,.22);
}
.btn-outline-light:hover{
  background: rgba(255,255,255,.10);
  border-color: rgba(255,255,255,.28);
}

/* =========================================================
   3) FORMS
   ========================================================= */
.form-label{
  font-size: .85rem;
  font-weight: 800;
  color: var(--muted);
}
.form-control, .form-select{
  border-radius: var(--radius-sm);
  border: 1px solid rgba(15,23,42,.14);
  padding: .62rem .88rem;
  background: rgba(255,255,255,.92);
  box-shadow: 0 8px 18px rgba(2,6,23,.06);
  transition: background-color .18s ease, border-color .18s ease, color .18s ease, box-shadow .18s ease, transform .18s ease;
}
html[data-theme="dark"] .form-control,
html[data-theme="dark"] .form-select{
  background: rgba(255,255,255,.06);
  border-color: rgba(255,255,255,.14);
  color: rgba(255,255,255,.92);
  box-shadow: 0 10px 22px rgba(0,0,0,.18);
}
.form-control:focus, .form-select:focus{
  box-shadow: var(--ring);
  border-color: rgba(79,70,229,.55);
}

/* =========================================================
   4) TABLES
   ========================================================= */
.table thead th{
  font-size: .78rem;
  text-transform: uppercase;
  letter-spacing: .06em;
  color: var(--muted);
  border-bottom: 1px solid var(--border);
}
.table td, .table th{
  border-color: var(--border);
  vertical-align: middle;
  white-space: nowrap;
  font-size: .9rem;
}
.table-hover tbody tr:hover{ background: rgba(79,70,229,.05); }
html[data-theme="dark"] .table-hover tbody tr:hover{ background: rgba(255,255,255,.06); }

/* Table container premium + sticky header */
.table-responsive{
  border-radius: 16px;
  overflow: hidden;
  border: 1px solid var(--border);
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}
.table thead th{
  background: rgba(255,255,255,.60);
  position: sticky;
  top: 0;
  z-index: 2;
}
html[data-theme="dark"] .table thead th{
  background: rgba(255,255,255,.06);
}

/* Dark mode bootstrap */
html[data-theme="dark"] .card,
html[data-theme="dark"] .alert{
  background: rgba(255,255,255,.06);
  border-color: rgba(255,255,255,.12);
  color: rgba(255,255,255,.92);
}
html[data-theme="dark"] .form-label{ color: rgba(255,255,255,.72); }
html[data-theme="dark"] .table thead th{
  color: rgba(255,255,255,.70);
  border-bottom-color: rgba(255,255,255,.12);
}
html[data-theme="dark"] .table td,
html[data-theme="dark"] .table th{
  border-color: rgba(255,255,255,.08);
}

/* =========================================================
   5) NAVBAR (shared)
   ========================================================= */
.px-navbar{
  border-radius: var(--radius);
  background:
    radial-gradient(900px circle at 12% 10%, rgba(6,182,212,.25), transparent 55%),
    radial-gradient(900px circle at 88% 18%, rgba(79,70,229,.22), transparent 55%),
    linear-gradient(180deg, #0b1220 0%, #0f172a 100%);
  border: 1px solid rgba(255,255,255,.10);
  box-shadow: 0 18px 50px rgba(2,6,23,.18);
  color: rgba(255,255,255,.92);
}
.px-navbar a{ color: rgba(255,255,255,.92); }
.px-navbar .muted{ color: rgba(255,255,255,.68); }

/* =========================================================
   6) LAYOUT SHELL
   ========================================================= */
.px-shell{
  min-height: 100vh;
  padding: 14px;
}
@media (max-width: 576px){
  .px-shell{ padding: 10px; }
}

/* Public container */
.px-shell-public{
  max-width: 1200px;
  margin: 0 auto;
}
@media (max-width: 576px){
  .px-shell-public{
    max-width: 100%;
    margin: 0;
    padding: 10px !important;
  }
}

/* Admin grid */
.px-grid{
  display:grid;
  grid-template-columns: 280px 1fr;
  gap: 14px;
}
@media(max-width: 991px){
  .px-grid{ grid-template-columns: 1fr; }
}

/* =========================================================
   7) SIDEBAR (admin)
   ========================================================= */
.px-sidebar{
  position: sticky;
  top: 14px;
  padding: 14px;
}
@media (max-width: 991px){
  .px-sidebar{
    position: static;
    top:auto;
  }
}

.px-menu-title{
  margin: 14px 8px 8px;
  font-size: .72rem;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: .10em;
  color: rgba(15,23,42,.65);
}

/* Light mode sidebar text */
.px-sidebar{ color: #0f172a; }
.px-menu a{
  display:flex;
  align-items:center;
  gap:10px;
  padding: 10px 12px;
  margin: 6px 0;
  border-radius: 14px;
  font-weight: 800;
  color: #0f172a !important;
  border: 1px solid transparent;
  opacity: 1;
}
.px-menu a:hover{
  background: rgba(79,70,229,.08);
  border-color: rgba(79,70,229,.18);
  color: #0f172a !important;
}
.px-menu a.active{
  background: linear-gradient(135deg, rgba(79,70,229,.18), rgba(6,182,212,.18));
  border-color: rgba(79,70,229,.35);
  color: #0f172a !important;
  box-shadow: 0 10px 26px rgba(79,70,229,.18);
}
.px-icon{ width: 26px; display:flex; align-items:center; justify-content:center; }

/* Dark mode sidebar */
html[data-theme="dark"] .px-menu-title{ color: rgba(255,255,255,.65); }
html[data-theme="dark"] .px-sidebar{ color: rgba(255,255,255,.92); }
html[data-theme="dark"] .px-menu a{
  color: rgba(255,255,255,.92) !important;
}
html[data-theme="dark"] .px-menu a:hover{
  background: rgba(255,255,255,.08);
  border-color: rgba(255,255,255,.12);
}
html[data-theme="dark"] .px-menu a.active{
  background: linear-gradient(135deg, rgba(79,70,229,.45), rgba(6,182,212,.25));
  border-color: rgba(99,102,241,.35);
  color: #fff !important;
  box-shadow: 0 14px 30px rgba(79,70,229,.14);
}

/* =========================================================
   8) CARDS (services)
   ========================================================= */
.px-cards{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
}
@media (max-width: 1024px){
  .px-cards{ grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 576px){
  .px-cards{ grid-template-columns: 1fr; }
}

.px-card{
  padding: 16px;
  border-radius: 18px;
  text-decoration: none;
  display:flex;
  flex-direction: column;
  gap: 6px;
  transition: background-color .18s ease, border-color .18s ease, color .18s ease, box-shadow .18s ease, transform .18s ease;
}

/* LIGHT MODE */
html:not([data-theme="dark"]) .px-card{
  background: #ffffff;
  border: 1px solid rgba(15,23,42,.10);
  color: rgba(15,23,42,.92);
  box-shadow: 0 12px 30px rgba(15,23,42,.10);
}

/* DARK MODE */
html[data-theme="dark"] .px-card{
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.14);
  color: rgba(255,255,255,.92);
  backdrop-filter: blur(14px);
}

/* Hover */
.px-card:hover{
  transform: translateY(-2px);
  box-shadow: 0 18px 45px rgba(2,6,23,.18);
}
.px-card .btn{ margin-top: auto; }

.px-card .fw-bold{
  font-size: 1rem;
  font-weight: 800;
}
.px-card .px-subtitle{
  font-size: .9rem;
  color: rgba(15,23,42,.65);
}
html[data-theme="dark"] .px-card .px-subtitle{
  color: rgba(255,255,255,.65);
}

/* =========================================================
   9) TABS (scrollable)
   ========================================================= */
.px-tabs{
  display:flex;
  gap:10px;
  align-items:center;
  overflow-x:auto;
  flex-wrap:nowrap;
  padding-bottom:6px;
  -webkit-overflow-scrolling: touch;
}
.px-tabs::-webkit-scrollbar{ display:none; }

.px-tab{
  flex:0 0 auto;
  padding:.55rem .85rem;
  border-radius:14px;
  border:1px solid rgba(255,255,255,.16);
  background: rgba(255,255,255,.06);
  color: rgba(255,255,255,.92);
  font-weight:900;
  white-space:nowrap;
}
.px-tab:hover{ background: rgba(255,255,255,.09); }
.px-tab.active{
  background: linear-gradient(135deg, rgba(79,70,229,.45), rgba(6,182,212,.20));
  border-color: rgba(99,102,241,.35);
}

/* =========================================================
   10) INFO BOX
   ========================================================= */
.px-info{
  padding: 14px;
  border-radius: 18px;
  border: 1px solid var(--border);
  background: var(--panel);
}
html[data-theme="dark"] .px-info{
  background: rgba(255,255,255,.06);
  border-color: rgba(255,255,255,.12);
}

/* =========================================================
   11) BACKEND POLISH HELPERS
   ========================================================= */
.admin-content{ padding: 18px; }
@media (max-width: 991px){
  .admin-content{ padding: 12px; }
}
.action-group{
  display:flex;
  gap:8px;
  flex-wrap: wrap;
  justify-content: flex-end;
}
@media (max-width: 576px){
  .action-group{ justify-content: flex-start; }
  .action-group .btn{ flex: 1 1 auto; }
}
@media (max-width: 576px){
  .page-head{
    flex-direction: column !important;
    align-items: stretch !important;
    gap: 10px !important;
  }
  .page-head .btn{ width: 100%; }
}
@media (max-width: 640px){
  .col-hide-sm{ display:none !important; }
  .table td, .table th{ padding: .55rem .65rem; }
  .table thead th{ font-size: .72rem; }
}

/* =========================================================
   12) OFFCANVAS POLISH
   ========================================================= */
.offcanvas{
  border-radius: 22px 0 0 22px;
}
.offcanvas .menu a{
  display:flex;
  align-items:center;
  gap:10px;
  padding: 10px 12px;
  border-radius: 14px;
  color: rgba(255,255,255,.90);
}
.offcanvas .menu a:hover{
  background: rgba(255,255,255,.08);
}

/* =========================================================
   13) ADMIN MOBILE FIX (WAJIB)
   - Navbar tidak kepotong
   - Tombol Menu/Dark/Logout rapi
   - Konten full terlihat
   - Table tidak rusak
   ========================================================= */
.px-nav-actions .btn{ white-space: nowrap; }

@media (max-width: 576px){

  /* NAVBAR: stack + grid */
  .px-navbar.px-nav-wrap{
    display: flex !important;
    flex-direction: column !important;
    align-items: stretch !important;
    justify-content: flex-start !important;
    gap: 12px !important;
    padding: 12px !important;
    border-radius: 16px !important;

    width: 100% !important;
    max-width: 100% !important;
    overflow: hidden !important;
  }

  .px-navbar .px-brand{
    width: 100% !important;
    min-width: 0 !important;
  }

  .px-navbar .px-nav-actions{
    width: 100% !important;
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 10px !important;
    align-items: stretch !important;
  }

  .px-navbar .px-nav-actions .btn{
    width: 100% !important;
    white-space: nowrap !important;
    padding: .60rem .75rem !important;
    border-radius: 14px !important;
    font-size: .95rem !important;
  }

  /* Logout full width (btn-primary biasanya Logout) */
  .px-navbar .px-nav-actions form{
    grid-column: 1 / span 2 !important;
  }

  /* GRID: jangan maksa sidebar */
  .px-grid{
    display: block !important;
  }

  /* konten */
  main .px-panel{
    padding: 14px !important;
  }

  /* Card/table agar tidak kepotong */
  .card, .px-panel, .px-glass{
    max-width: 100% !important;
    overflow: hidden !important;
  }

  /* Table: scroll horizontal */
  .table-responsive{
    overflow-x: auto !important;
    -webkit-overflow-scrolling: touch !important;
  }
  .table{
    min-width: 760px;
  }

  /* Mobile round */
  .px-navbar{ border-radius: 14px; }
  .px-panel, .px-glass{ border-radius: 16px; }
  .px-glass{ padding: 14px !important; }

  /* Optional hide columns helper */
  .col-hide-mobile{ display:none !important; }
}

/* =========================================================
   14) SMOOTH TRANSITION + REDUCE MOTION
   ========================================================= */
html, body, .px-glass, .px-panel, .px-card, .card, .btn, .form-control, .form-select, .table{
  transition: background-color .18s ease, border-color .18s ease, color .18s ease, box-shadow .18s ease, transform .18s ease;
}
@media (prefers-reduced-motion: reduce){
  *{ transition: none !important; }
}
