/* style.css paket - disesuaikan dengan UI landingpage */
*,
*::before,
*::after{
  box-sizing:border-box;
}

:root{
  --red:#e60000;
  --red-dark:#b80000;
  --red-soft:#fff1f1;
  --green:#25d366;
  --green-dark:#19984d;

  --white:#ffffff;
  --black:#0f1115;
  --gray-50:#fcfcfe;
  --gray-100:#f3f5f9;
  --gray-400:#9ca4b5;
  --gray-500:#71798c;
  --gray-600:#5a6273;
  --gray-700:#313746;
  --gray-800:#1c2230;

  --accent:var(--red);
  --accent-dark:var(--red-dark);
  --bg:#fbfbfd;
  --bg-soft:#f5f7fb;
  --surface:#ffffff;
  --text:var(--gray-800);
  --text-muted:var(--gray-600);
  --border:rgba(15,17,21,.06);
  --border-strong:rgba(230,0,0,.16);

  --shadow-sm:0 8px 24px rgba(16,17,20,.06);
  --shadow-md:0 20px 48px rgba(16,17,20,.10);
  --shadow-lg:0 30px 80px rgba(16,17,20,.18);
  --shadow-red:0 18px 36px rgba(230,0,0,.22);

  --pill:999px;
  --radius-xl:30px;
  --radius-lg:26px;
  --radius-md:22px;
  --radius-sm:18px;
  --transition:.3s cubic-bezier(.4,0,.2,1);
  --focus:0 0 0 3px rgba(230,0,0,.20);
  --container:1180px;
  --font:"Inter",system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
}

html{scroll-behavior:smooth;}

body{
  margin:0;
  min-height:100vh;
  font-family:var(--font);
  line-height:1.6;
  color:var(--text);
  background:
    radial-gradient(circle at top left, rgba(230,0,0,.05), transparent 24%),
    linear-gradient(180deg,#fbfbfd 0%,#f5f7fb 100%);
  overflow-x:hidden;
  text-rendering:optimizeLegibility;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}

body.no-scroll{overflow:hidden;}

img,
svg{
  max-width:100%;
  height:auto;
  display:block;
}

button,
a{font:inherit;}
button{cursor:pointer;}
a{color:inherit;text-decoration:none;}

::selection{background:rgba(230,0,0,.15);}

:focus-visible{
  outline:none;
  box-shadow:var(--focus);
}

@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto;}
  *,*::before,*::after{
    animation:none!important;
    transition:none!important;
  }
}

.skip-link{
  position:absolute;
  left:-9999px;
  top:auto;
}

.skip-link:focus{
  left:16px;
  top:16px;
  z-index:9999;
  padding:10px 14px;
  border-radius:14px;
  border:1px solid var(--border);
  background:#fff;
  color:var(--black);
  box-shadow:var(--shadow-sm);
}

.page-shell{
  width:100%;
  max-width:none;
  margin:0;
  padding:28px 32px 70px;
}

/* HERO */
.hero{
  position:relative;
  isolation:isolate;
  overflow:hidden;
  display:grid;
  grid-template-columns:1.1fr .9fr;
  gap:28px;
  align-items:center;
  margin-bottom:28px;
  padding:48px 42px;
  border-radius:32px;
  background:linear-gradient(180deg,#101114 0%,#14161c 100%);
  box-shadow:var(--shadow-lg);
}

.hero::before{
  content:"";
  position:absolute;
  top:-180px;
  right:-140px;
  width:560px;
  height:560px;
  border-radius:50%;
  background:radial-gradient(circle,rgba(255,255,255,.16),transparent 70%);
  pointer-events:none;
  z-index:-1;
}

.hero::after{
  content:"";
  position:absolute;
  left:-120px;
  bottom:-220px;
  width:480px;
  height:480px;
  border-radius:50%;
  background:radial-gradient(circle,rgba(230,0,0,.28),transparent 70%);
  pointer-events:none;
  z-index:-1;
}

.hero-copy{color:#fff;}

.eyebrow{
  display:inline-flex;
  align-items:center;
  gap:6px;
  margin:0 0 16px;
  padding:8px 16px;
  border-radius:var(--pill);
  border:1px solid rgba(255,255,255,.18);
  background:rgba(255,255,255,.10);
  color:#ffd7d7;
  font-size:12px;
  font-weight:800;
  letter-spacing:.7px;
  text-transform:uppercase;
  backdrop-filter:blur(8px);
}

.hero-title{
  max-width:760px;
  margin:0 0 18px;
  font-size:clamp(2.6rem,5vw,4.9rem);
  line-height:1.03;
  font-weight:800;
  letter-spacing:-2px;
  color:#fff;
}

.hero-desc{
  max-width:680px;
  margin:0;
  color:rgba(255,255,255,.88);
  font-size:clamp(1rem,1.8vw,1.12rem);
}

.hero-badges{
  list-style:none;
  padding:0;
  margin:30px 0 0;
  display:flex;
  flex-wrap:wrap;
  gap:10px;
}

.badge{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:38px;
  padding:8px 14px;
  border-radius:var(--pill);
  border:1px solid rgba(255,255,255,.16);
  background:rgba(255,255,255,.10);
  color:rgba(255,255,255,.88);
  box-shadow:none;
  font-size:13px;
  font-weight:700;
  backdrop-filter:blur(10px);
}

.hero-media{
  min-width:0;
  display:flex;
  justify-content:center;
}

.hero-logo-box{
  display:flex;
  align-items:center;
  justify-content:center;
  width:100%;
  max-width:380px;
  min-height:280px;
  padding:28px;
  border-radius:var(--radius-xl);
  border:1px solid rgba(255,255,255,.80);
  background:rgba(255,255,255,.96);
  box-shadow:0 30px 80px rgba(0,0,0,.22);
}

.hero-logo{
  width:min(340px,100%);
  object-fit:contain;
}

/* TABS */
.tabs-wrap{
  margin:0 0 26px;
}

.tabs{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  justify-content:center;
}

.tab-btn{
  min-height:44px;
  padding:10px 18px;
  border-radius:var(--pill);
  border:1px solid rgba(15,17,21,.06);
  background:#fff;
  color:var(--gray-600);
  font-size:14px;
  font-weight:800;
  box-shadow:var(--shadow-sm);
  transition:transform var(--transition), background var(--transition), color var(--transition), border-color var(--transition), box-shadow var(--transition);
}

.tab-btn:hover{
  transform:translateY(-3px);
  color:var(--red);
  background:var(--red-soft);
  border-color:rgba(230,0,0,.12);
  box-shadow:var(--shadow-md);
}

.tab-btn[aria-selected="true"]{
  color:#fff;
  border-color:transparent;
  background:linear-gradient(135deg,var(--red),var(--red-dark));
  box-shadow:var(--shadow-red);
}

/* SECTION */
.section{
  position:relative;
  margin-bottom:22px;
  padding:30px 24px;
  border:1px solid rgba(15,17,21,.06);
  border-radius:var(--radius-xl);
  background:rgba(255,255,255,.92);
  box-shadow:var(--shadow-sm);
  content-visibility:auto;
  contain-intrinsic-size:800px;
}

.section-head{
  display:flex;
  justify-content:space-between;
  align-items:flex-end;
  gap:16px;
  margin-bottom:22px;
}

.section-title{
  margin:0;
  font-size:clamp(1.45rem,2.5vw,2.2rem);
  line-height:1.12;
  letter-spacing:-.8px;
  font-weight:800;
  color:var(--black);
}

.section-sub{
  font-size:14px;
  color:var(--gray-600);
}

/* GRID */
.pkg-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(230px,1fr));
  gap:18px;
  align-items:stretch;
}

.pkg-grid.single{
  justify-content:center;
}

.pkg-grid.single .paket-card{
  max-width:560px;
  justify-self:center;
}

/* CARD */
.paket-card{
  position:relative;
  overflow:hidden;
  display:flex;
  flex-direction:column;
  min-height:320px;
  padding:20px 18px;
  border:1px solid rgba(15,17,21,.06);
  border-radius:26px;
  background:#fff;
  box-shadow:var(--shadow-sm);
  transition:transform var(--transition), box-shadow var(--transition), border-color var(--transition);
  contain:layout paint style;
}

.paket-card::before{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(180deg,rgba(230,0,0,.04),transparent 35%);
  opacity:0;
  transition:opacity var(--transition);
  pointer-events:none;
}

.paket-card:hover{
  transform:translateY(-8px);
  border-color:rgba(230,0,0,.14);
  box-shadow:var(--shadow-md);
}

.paket-card:hover::before{opacity:1;}

.card-inner{
  position:relative;
  z-index:1;
  display:flex;
  flex-direction:column;
  height:100%;
  gap:14px;
}

.card-header{
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:14px;
  text-align:center;
}

.card-header-left{
  display:flex;
  justify-content:center;
}

.ring{
  --angle:0deg;
  position:relative;
  width:88px;
  height:88px;
  display:grid;
  place-items:center;
  border-radius:50%;
  background:
    conic-gradient(var(--red) var(--angle), rgba(15,17,21,.10) 0deg);
  box-shadow:0 10px 26px rgba(16,17,20,.10);
}

.ring::after{
  content:"";
  position:absolute;
  inset:12px;
  border-radius:50%;
  background:#fff;
  border:1px solid rgba(15,17,21,.08);
}

.ring::after{
  content:"";
  position:absolute;
  inset:auto;
  width:0;
  height:0;
}

.ring span{
  position:relative;
  z-index:1;
  font-size:1.05rem;
  font-weight:900;
  letter-spacing:-.02em;
}

.card-header-right{
  flex:1;
  min-width:0;
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:8px;
}

.paket-title{
  margin:0;
  font-size:18px;
  line-height:1.25;
  letter-spacing:-.4px;
  font-weight:800;
  color:var(--black);
  text-align:center;
  text-wrap:balance;
}

.price-block{text-align:center;}

.price-main{
  font-size:24px;
  line-height:1.1;
  font-weight:800;
  letter-spacing:-.8px;
  color:var(--black);
}

.price-note{
  margin-top:2px;
  font-size:13px;
  font-weight:600;
  color:var(--gray-500);
}

.benefit-list{
  width:100%;
  max-width:230px;
  margin:6px auto 0;
  padding:0;
  list-style:none;
  text-align:center;
  color:var(--gray-600);
  font-size:13px;
  line-height:1.6;
}

.benefit-list li + li{margin-top:4px;}

/* ACTIONS */
.card-actions{
  display:flex;
  gap:9px;
  margin-top:auto;
  padding-top:14px;
  border-top:1px solid rgba(15,17,21,.06);
}

.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  min-height:46px;
  padding:13px 16px;
  border:none;
  border-radius:var(--pill);
  cursor:pointer;
  font-size:14px;
  font-weight:800;
  transition:transform var(--transition), background var(--transition), box-shadow var(--transition), border-color var(--transition), color var(--transition);
}

.btn:hover{transform:translateY(-2px);}

.btn-primary{
  flex:1;
  color:#fff;
  background:linear-gradient(135deg,var(--red),var(--red-dark));
  box-shadow:0 14px 26px rgba(230,0,0,.18);
}

.btn-ghost{
  flex:1;
  color:var(--red);
  background:#fff;
  border:1px solid rgba(230,0,0,.14);
}

.btn-ghost:hover{
  background:var(--red-soft);
  box-shadow:0 14px 26px rgba(230,0,0,.08);
}

/* LOADING */
.paket-loading{
  width:fit-content;
  margin:0 auto 24px;
  padding:10px 16px;
  border-radius:var(--pill);
  border:1px solid rgba(15,17,21,.06);
  background:#fff;
  box-shadow:var(--shadow-sm);
  color:var(--gray-600);
  text-align:center;
  font-size:13px;
  font-weight:700;
}

/* MODAL */
.modal-overlay{
  position:fixed;
  inset:0;
  z-index:2000;
  display:block;
  width:100%;
  height:100dvh;
  overflow-y:auto;
  overflow-x:hidden;
  padding:24px 16px;
  background-color:rgba(0,0,0,.66);
  backdrop-filter:blur(6px);
}

.modal-overlay[hidden]{display:none;}

.modal-card{
  position:relative;
  width:min(100%,520px);
  max-height:none;
  overflow:visible;
  margin:0 auto;
  padding:30px;
  border-radius:28px;
  border:0;
  background:#fff;
  box-shadow:var(--shadow-lg);
  animation:modalFadeIn .28s cubic-bezier(.4,0,.2,1);
}

@keyframes modalFadeIn{
  from{opacity:0;transform:translateY(10px) scale(.96);}
  to{opacity:1;transform:none;}
}

.modal-header{
  display:flex;
  justify-content:space-between;
  gap:16px;
  align-items:flex-start;
  margin-bottom:16px;
}

.modal-title{
  margin:0 0 6px;
  font-size:24px;
  line-height:1.2;
  font-weight:800;
  color:var(--black);
}

.modal-close{
  flex:0 0 auto;
  display:flex;
  align-items:center;
  justify-content:center;
  width:34px;
  height:34px;
  border:0;
  border-radius:10px;
  background:transparent;
  color:var(--gray-400);
  cursor:pointer;
  font-size:28px;
  line-height:1;
  transition:var(--transition);
}

.modal-close:hover{
  color:var(--red);
  background:var(--red-soft);
}

.modal-scheme-tabs{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin-bottom:14px;
}

.modal-scheme-btn{
  min-height:38px;
  padding:8px 13px;
  border-radius:var(--pill);
  border:1px solid transparent;
  background:#f1f5f9;
  color:var(--gray-700);
  cursor:pointer;
  font-size:12px;
  font-weight:700;
  transition:all .2s ease;
}

.modal-scheme-btn:hover{
  transform:translateY(-1px);
  border-color:#fecaca;
}

.modal-scheme-btn[aria-selected="true"]{
  color:#fff;
  border-color:var(--red);
  background:var(--red);
  box-shadow:0 6px 14px rgba(230,0,0,.22);
}

/* ACCORDION */
.modal-accordion{
  display:grid;
  gap:12px;
}

.modal-accordion-item{
  overflow:hidden;
  border:1px solid rgba(15,17,21,.05);
  border-radius:22px;
  background:#fff;
  box-shadow:var(--shadow-sm);
  transition:box-shadow var(--transition), border-color var(--transition);
}

.modal-accordion-item:hover{box-shadow:var(--shadow-md);}

.modal-accordion-btn{
  width:100%;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  padding:18px 20px;
  border:0;
  background:#fff;
  color:var(--black);
  cursor:pointer;
  text-align:left;
  font-size:15px;
  font-weight:800;
}

.modal-accordion-btn:hover,
.modal-accordion-btn[aria-expanded="true"]{
  color:var(--red);
  background:#fff;
}

.modal-accordion-icon{
  flex:0 0 auto;
  width:24px;
  height:24px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:999px;
  color:var(--gray-400);
  font-size:0;
  line-height:1;
  position:relative;
  transition:transform .35s ease,color .35s ease;
}

.modal-accordion-icon::before{
  content:"+";
  font-size:20px;
  font-weight:800;
  line-height:1;
}

.modal-accordion-btn[aria-expanded="true"] .modal-accordion-icon{
  color:var(--red);
  transform:rotate(45deg);
}

.modal-accordion-panel{
  padding:0 20px 20px;
}

/* BENEFIT BLOCK */
.modal-benefits-wrap{
  margin:0;
  padding:14px 16px;
  border:1px solid #ffcccc;
  border-radius:16px;
  background:#fff5f5;
}

.modal-benefit-list{
  margin:0;
  padding:0;
  list-style:none;
  display:grid;
  gap:8px;
}

.modal-benefit-list li{
  position:relative;
  padding:10px 12px 10px 34px;
  border:1px solid rgba(230,0,0,.10);
  border-radius:12px;
  background:#fff;
  color:var(--gray-700);
  font-size:13px;
  line-height:1.55;
}

.modal-benefit-list li::before{
  content:"✓";
  position:absolute;
  top:50%;
  left:12px;
  transform:translateY(-50%);
  width:16px;
  height:16px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:999px;
  background:var(--red);
  color:#fff;
  font-size:10px;
  font-weight:800;
}

/* BIAYA BLOCK */
.modal-biaya-wrap{
  padding:14px 16px;
  border:1px solid #e8e8e8;
  border-radius:16px;
  background:#f8f9fa;
}

.modal-table{
  width:100%;
  border-collapse:collapse;
  font-size:13px;
}

.modal-table td{
  padding:6px 0;
  vertical-align:top;
}

.modal-table td:first-child{color:var(--gray-600);}

.modal-table td:last-child{
  text-align:right;
  font-variant-numeric:tabular-nums;
  color:var(--black);
  font-weight:700;
}

.modal-sep{
  border-top:1px dashed rgba(15,17,21,.18);
  margin:12px 0;
}

.modal-summary{
  display:flex;
  justify-content:space-between;
  gap:12px;
}

.modal-summary-main{
  font-weight:900;
  color:var(--black);
}

.modal-summary-note{
  text-align:right;
  color:var(--gray-600);
  font-size:12px;
}

.modal-footer-text{
  margin:12px 0 0;
  color:var(--gray-600);
  font-size:13px;
  line-height:1.65;
}

.modal-footer-actions{
  display:flex;
  gap:10px;
  justify-content:flex-end;
  margin-top:18px;
}

.modal-footer-actions .btn{flex:1;}

/* RESPONSIVE */
@media (max-width:1024px){
  .hero{
    grid-template-columns:1fr;
    gap:26px;
  }

  .hero-media{
    justify-content:flex-start;
  }

  .section-head{
    flex-direction:column;
    align-items:flex-start;
    gap:8px;
  }
}

@media (max-width:768px){
  .page-shell{
    padding:18px 16px 54px;
  }

  .hero{
    min-height:auto;
    padding:54px 22px;
    border-radius:28px;
    text-align:center;
  }

  .hero-desc{
    margin-left:auto;
    margin-right:auto;
  }

  .hero-badges{
    justify-content:center;
  }

  .hero-media{
    justify-content:center;
  }

  .hero-logo-box{
    max-width:100%;
    min-height:220px;
  }

  .section{
    padding:24px 16px;
  }

  .pkg-grid{
    grid-template-columns:1fr;
  }

  .card-actions{
    flex-direction:column;
  }

  .modal-card{
    padding:24px 18px;
  }

  .modal-title{
    font-size:22px;
  }

  .modal-footer-actions{
    flex-direction:column;
  }
}

@media (max-width:480px){
  .hero-title{
    font-size:clamp(2.15rem,13vw,3rem);
  }

  .tabs{
    justify-content:flex-start;
    overflow-x:auto;
    flex-wrap:nowrap;
    padding-bottom:8px;
    scrollbar-width:none;
  }

  .tabs::-webkit-scrollbar{display:none;}

  .tab-btn{
    white-space:nowrap;
  }

  .modal-accordion-btn{
    padding:18px;
    font-size:14px;
  }

  .modal-accordion-panel{
    padding:0 18px 18px;
  }
}
.form-grid {
  display: grid;
  gap: 14px;
}

.form-field {
  width: 100%;
  border: 1px solid #ffd7d7;
  border-radius: 18px;
  padding: 16px 18px;
  font: inherit;
  font-size: 15px;
  line-height: 1.4;
  color: #1f2937;
  background: #fff;
  outline: none;
  box-sizing: border-box;
}

.form-field::placeholder {
  color: #6b7280;
}

.form-field:focus {
  border-color: #ef0000;
  box-shadow: 0 0 0 3px rgba(239, 0, 0, 0.08);
}

.form-field[readonly] {
  background: #f9fafb;
  color: #4b5563;
  cursor: not-allowed;
}

textarea.form-field {
  resize: vertical;
  min-height: 90px;
}