/* =============================================
   DASAKITA — PT. Dasa Kita Finansial
   Style: Refined Financial / Elegant Modern
   ============================================= */

@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,400;0,500;0,600;0,700;1,400;1,500&family=DM+Sans:wght@300;400;500;600&display=swap');

:root {
  --navy:   #0D2B45;
  --teal:   #0D6E8A;
  --teal-light: #12A3C4;
  --gold:   #E8A820;
  --gold-light: #F4C455;
  --cream:  #FAF7F2;
  --white:  #FFFFFF;
  --gray:   #6B7A8D;
  --gray-light: #ECF0F4;
  --text:   #1A2E40;
  --shadow: 0 8px 40px rgba(13,43,69,0.12);
  --shadow-hover: 0 16px 60px rgba(13,43,69,0.20);
  --radius: 12px;
  --transition: all 0.35s cubic-bezier(0.4,0,0.2,1);
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

html { scroll-behavior: smooth; font-size: 16px; }

body {
  font-family: 'DM Sans', sans-serif;
  color: var(--text);
  background: var(--white);
  overflow-x: hidden;
  line-height: 1.7;
}

/* ── TYPOGRAPHY ── */
h1,h2,h3,h4 { font-family: 'Cormorant Garamond', serif; line-height: 1.2; }
h1 { font-size: clamp(2.4rem, 5vw, 3.8rem); font-weight: 600; }
h2 { font-size: clamp(1.8rem, 3.5vw, 2.8rem); font-weight: 600; }
h3 { font-size: clamp(1.3rem, 2.5vw, 1.7rem); font-weight: 500; }
p  { font-size: 1rem; color: var(--gray); }
a  { text-decoration: none; color: inherit; }

.section { padding: 90px 0; }
.container { max-width: 1180px; margin: 0 auto; padding: 0 24px; }
.text-center { text-align: center; }
.tag {
  display: inline-block;
  background: rgba(13,110,138,0.1);
  color: var(--teal);
  font-size: 0.78rem;
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  padding: 6px 16px;
  border-radius: 99px;
  margin-bottom: 16px;
}
.section-title { margin-bottom: 16px; }
.section-sub  { max-width: 540px; margin: 0 auto 52px; color: var(--gray); font-size: 1.05rem; }

/* ── BUTTONS ── */
.btn {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 14px 32px;
  border-radius: 8px;
  font-family: 'DM Sans', sans-serif;
  font-size: 0.95rem; font-weight: 500;
  cursor: pointer; border: none;
  transition: var(--transition);
}
.btn-primary {
  background: var(--gold);
  color: var(--navy);
}
.btn-primary:hover { background: var(--gold-light); transform: translateY(-2px); box-shadow: 0 8px 24px rgba(232,168,32,0.35); }
.btn-outline {
  background: transparent;
  border: 2px solid rgba(255,255,255,0.5);
  color: var(--white);
}
.btn-outline:hover { background: rgba(255,255,255,0.12); border-color: var(--white); }
.btn-teal { background: var(--teal); color: var(--white); }
.btn-teal:hover { background: var(--teal-light); transform: translateY(-2px); }

/* ── NAVBAR ── */
#navbar {
  position: fixed; top: 0; left: 0; right: 0; z-index: 1000;
  padding: 0 24px;
  transition: var(--transition);
}
#navbar.scrolled {
  background: rgba(13,43,69,0.97);
  backdrop-filter: blur(12px);
  box-shadow: 0 2px 24px rgba(0,0,0,0.18);
}
.nav-inner {
  max-width: 1180px; margin: 0 auto;
  display: flex; align-items: center; justify-content: space-between;
  height: 72px;
}
.nav-logo { display: flex; align-items: center; gap: 12px; }
.nav-logo-mark {
  width: 42px; height: 42px;
  background: var(--gold);
  border-radius: 10px;
  display: flex; align-items: center; justify-content: center;
  font-family: 'Cormorant Garamond', serif;
  font-size: 1.4rem; font-weight: 700; color: var(--navy);
}
.nav-logo-text { color: var(--white); font-family: 'Cormorant Garamond', serif; font-size: 1.3rem; font-weight: 600; line-height: 1.1; }
.nav-logo-text span { display: block; font-family: 'DM Sans', sans-serif; font-size: 0.62rem; font-weight: 400; letter-spacing: 0.14em; text-transform: uppercase; opacity: 0.65; }
.nav-links { display: flex; align-items: center; gap: 4px; }
.nav-links a {
  color: rgba(255,255,255,0.82);
  font-size: 0.9rem; font-weight: 400;
  padding: 8px 14px; border-radius: 6px;
  transition: var(--transition);
}
.nav-links a:hover { color: var(--white); background: rgba(255,255,255,0.1); }
.nav-cta { display: flex; align-items: center; gap: 10px; }
.nav-login {
  color: rgba(255,255,255,0.82);
  font-size: 0.9rem; padding: 8px 16px;
  border: 1px solid rgba(255,255,255,0.25);
  border-radius: 7px;
  transition: var(--transition);
}
.nav-login:hover { color: var(--white); border-color: rgba(255,255,255,0.6); }
.nav-register {
  background: var(--gold);
  color: var(--navy) !important;
  font-weight: 600 !important;
  padding: 9px 20px !important;
  border-radius: 7px;
}
.nav-register:hover { background: var(--gold-light) !important; }

/* Hamburger */
.nav-hamburger {
  display: none; flex-direction: column; gap: 5px;
  cursor: pointer; padding: 6px;
}
.nav-hamburger span {
  width: 26px; height: 2px;
  background: var(--white); border-radius: 2px;
  transition: var(--transition);
}
.nav-mobile { display: none; }

@media(max-width:900px){
  .nav-links,.nav-cta { display:none; }
  .nav-hamburger { display:flex; }
  .nav-mobile {
    display: none;
    position: fixed; top: 72px; left: 0; right: 0;
    background: var(--navy);
    padding: 20px 24px 28px;
    flex-direction: column; gap: 4px;
    box-shadow: 0 12px 32px rgba(0,0,0,0.25);
    z-index: 999;
  }
  .nav-mobile.open { display:flex; }
  .nav-mobile a { color: rgba(255,255,255,0.85); font-size:1rem; padding:12px 0; border-bottom:1px solid rgba(255,255,255,0.08); }
  .nav-mobile a:last-child { border:none; }
  .nav-mobile .mob-cta { margin-top:12px; display:flex; gap:10px; flex-wrap:wrap; }
}

/* ── HERO ── */
#hero {
  min-height: 100vh;
  background: linear-gradient(145deg, #062236 0%, #0D2B45 50%, #0D4C6E 100%);
  position: relative;
  display: flex; align-items: center;
  overflow: hidden;
  padding-top: 72px;
}
.hero-bg-pattern {
  position: absolute; inset: 0;
  background-image:
    radial-gradient(circle at 75% 40%, rgba(13,110,138,0.25) 0%, transparent 55%),
    radial-gradient(circle at 20% 70%, rgba(232,168,32,0.08) 0%, transparent 45%);
  pointer-events: none;
}
.hero-grid-lines {
  position: absolute; inset: 0;
  background-image:
    linear-gradient(rgba(255,255,255,0.03) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.03) 1px, transparent 1px);
  background-size: 60px 60px;
  pointer-events: none;
}
.hero-inner {
  max-width: 1180px; margin: 0 auto; padding: 80px 24px;
  display: grid; grid-template-columns: 1fr 1fr; gap: 64px; align-items: center;
}
.hero-badge {
  display: inline-flex; align-items: center; gap: 8px;
  background: rgba(232,168,32,0.15);
  border: 1px solid rgba(232,168,32,0.3);
  color: var(--gold-light);
  font-size: 0.78rem; font-weight: 500; letter-spacing: 0.1em; text-transform: uppercase;
  padding: 7px 16px; border-radius: 99px;
  margin-bottom: 24px;
}
.hero-badge::before { content:''; width:7px; height:7px; background:var(--gold); border-radius:50%; }
.hero-title { color: var(--white); margin-bottom: 20px; }
.hero-title em { color: var(--gold); font-style: normal; }
.hero-desc { color: rgba(255,255,255,0.68); font-size: 1.08rem; max-width: 440px; margin-bottom: 36px; }
.hero-buttons { display: flex; gap: 14px; flex-wrap: wrap; margin-bottom: 48px; }
.hero-stats { display: flex; gap: 32px; flex-wrap: wrap; }
.hero-stat-num { font-family: 'Cormorant Garamond', serif; font-size: 2rem; font-weight: 700; color: var(--white); }
.hero-stat-label { font-size: 0.8rem; color: rgba(255,255,255,0.5); }
.hero-img-wrap {
  position: relative;
}
.hero-img-wrap img {
  width: 100%; border-radius: 20px;
  box-shadow: 0 32px 80px rgba(0,0,0,0.35);
  display: block;
}
.hero-img-card {
  position: absolute; bottom: -16px; left: -20px;
  background: var(--white);
  border-radius: 14px;
  padding: 16px 20px;
  box-shadow: var(--shadow);
  display: flex; align-items: center; gap: 12px;
}
.hero-card-icon { width:42px; height:42px; background: rgba(13,110,138,0.12); border-radius:10px; display:flex; align-items:center; justify-content:center; color:var(--teal); font-size:1.2rem; }
.hero-card-num { font-family:'Cormorant Garamond',serif; font-size:1.4rem; font-weight:700; color:var(--navy); }
.hero-card-lbl { font-size:0.75rem; color:var(--gray); }

@media(max-width:768px){
  .hero-inner { grid-template-columns:1fr; gap:40px; }
  .hero-img-wrap { display:none; }
}

/* ── TRUST BAR ── */
#trust-bar {
  background: var(--navy);
  padding: 20px 24px;
}
.trust-inner {
  max-width:1180px; margin:0 auto;
  display:flex; align-items:center; gap:32px; flex-wrap:wrap; justify-content:center;
}
.trust-item { display:flex; align-items:center; gap:10px; color:rgba(255,255,255,0.65); font-size:0.84rem; }
.trust-item i { color:var(--gold); font-size:1.1rem; }
.trust-sep { width:1px; height:28px; background:rgba(255,255,255,0.1); }
@media(max-width:600px){ .trust-sep { display:none; } }

/* ── PRODUCTS ── */
#products { background: var(--cream); }
.products-grid {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); gap: 24px;
}
.product-card {
  background: var(--white);
  border-radius: var(--radius);
  padding: 36px 28px;
  border: 1px solid #E8EDF2;
  transition: var(--transition);
  position: relative;
  overflow: hidden;
}
.product-card::before {
  content: '';
  position: absolute; top:0; left:0; right:0; height:4px;
  background: linear-gradient(90deg, var(--teal), var(--gold));
  transform: scaleX(0);
  transition: var(--transition);
}
.product-card:hover { transform: translateY(-6px); box-shadow: var(--shadow-hover); }
.product-card:hover::before { transform: scaleX(1); }
.product-icon {
  width:60px; height:60px;
  background: linear-gradient(135deg, rgba(13,110,138,0.12) 0%, rgba(232,168,32,0.1) 100%);
  border-radius:14px;
  display:flex; align-items:center; justify-content:center;
  font-size:1.5rem; color:var(--teal);
  margin-bottom:20px;
}
.product-card h3 { color:var(--navy); margin-bottom:10px; }
.product-card p { font-size:0.93rem; margin-bottom:20px; }
.product-link { color:var(--teal); font-size:0.9rem; font-weight:500; display:flex; align-items:center; gap:6px; transition:var(--transition); }
.product-link:hover { gap:10px; color:var(--gold); }

/* ── HOW IT WORKS ── */
#how { background: var(--white); }
.steps-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(200px,1fr)); gap:40px; }
.step { text-align:center; }
.step-num {
  width:56px; height:56px;
  background:linear-gradient(135deg,var(--navy),var(--teal));
  border-radius:50%; color:var(--white);
  font-family:'Cormorant Garamond',serif;
  font-size:1.5rem; font-weight:700;
  display:flex; align-items:center; justify-content:center;
  margin:0 auto 20px;
}
.step h3 { color:var(--navy); margin-bottom:10px; }

/* ── WHY US ── */
#why { background: var(--cream); }
.why-grid { display:grid; grid-template-columns:1fr 1fr; gap:64px; align-items:center; }
.why-img img { width:100%; border-radius:20px; box-shadow:var(--shadow); }
.why-features { display:flex; flex-direction:column; gap:24px; }
.why-feat { display:flex; gap:18px; align-items:flex-start; }
.why-feat-icon {
  width:48px; height:48px; min-width:48px;
  background:var(--navy); color:var(--gold);
  border-radius:12px; display:flex; align-items:center; justify-content:center;
  font-size:1.2rem;
}
.why-feat h4 { font-family:'DM Sans',sans-serif; font-size:1rem; font-weight:600; color:var(--navy); margin-bottom:4px; }
.why-feat p { font-size:0.9rem; }
@media(max-width:768px){ .why-grid { grid-template-columns:1fr; } .why-img { display:none; } }

/* ── STATS ── */
#stats {
  background: linear-gradient(135deg, var(--navy) 0%, #0D4C6E 100%);
  padding: 70px 0;
}
.stats-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(160px,1fr)); gap:32px; text-align:center; }
.stat-num { font-family:'Cormorant Garamond',serif; font-size:2.8rem; font-weight:700; color:var(--gold); }
.stat-label { color:rgba(255,255,255,0.65); font-size:0.9rem; margin-top:4px; }

/* ── TESTIMONIALS ── */
#testimonials { background: var(--white); }
.testi-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(280px,1fr)); gap:24px; }
.testi-card {
  background:var(--cream);
  border-radius:var(--radius);
  padding:32px;
  border:1px solid #E8EDF2;
  transition:var(--transition);
}
.testi-card:hover { box-shadow:var(--shadow); }
.testi-stars { color:var(--gold); margin-bottom:14px; letter-spacing:2px; }
.testi-text { font-size:0.96rem; color:var(--text); margin-bottom:20px; font-style:italic; }
.testi-author { display:flex; align-items:center; gap:12px; }
.testi-avatar {
  width:42px; height:42px; border-radius:50%;
  background:linear-gradient(135deg,var(--teal),var(--navy));
  display:flex; align-items:center; justify-content:center;
  color:var(--white); font-weight:700; font-size:1rem;
}
.testi-name { font-weight:600; color:var(--navy); font-size:0.9rem; }
.testi-role { font-size:0.78rem; color:var(--gray); }

/* ── PARTNERS ── */
#partners { background: var(--cream); padding:60px 0; }
.partners-label { text-align:center; color:var(--gray); font-size:0.82rem; letter-spacing:0.12em; text-transform:uppercase; margin-bottom:32px; font-weight:500; }
.partners-logos { display:flex; flex-wrap:wrap; justify-content:center; align-items:center; gap:32px 48px; }
.partner-logo { color:var(--gray); font-weight:600; font-size:0.95rem; opacity:0.6; transition:var(--transition); letter-spacing:0.05em; text-transform:uppercase; }
.partner-logo:hover { opacity:1; color:var(--teal); }

/* ── FAQ ── */
#faq { background: var(--white); }
.faq-list { max-width: 760px; margin: 0 auto; display: flex; flex-direction: column; gap: 12px; }
.faq-item { border: 1px solid #E8EDF2; border-radius: var(--radius); overflow: hidden; }
.faq-q {
  padding:20px 24px; font-weight:500; color:var(--navy);
  cursor:pointer; display:flex; justify-content:space-between; align-items:center;
  user-select:none; transition:var(--transition);
}
.faq-q:hover { background:var(--cream); }
.faq-q .ico { font-size:1.1rem; color:var(--teal); transition:var(--transition); }
.faq-q.open .ico { transform:rotate(45deg); }
.faq-a { display:none; padding:0 24px 20px; color:var(--gray); font-size:0.95rem; }
.faq-a.open { display:block; }

/* ── EMAIL OPT-IN ── */
#newsletter {
  background: linear-gradient(135deg, #0D4C6E 0%, var(--navy) 100%);
  padding: 80px 24px;
  text-align: center;
}
#newsletter h2 { color: var(--white); }
#newsletter p { color: rgba(255,255,255,0.65); max-width:480px; margin:12px auto 32px; }
.newsletter-form { display:flex; gap:12px; justify-content:center; flex-wrap:wrap; max-width:500px; margin:0 auto; }
.newsletter-form input {
  flex:1; min-width:220px;
  padding:14px 20px;
  border-radius:8px; border:none;
  font-family:'DM Sans',sans-serif; font-size:0.95rem;
  outline:none;
}
.newsletter-form input:focus { box-shadow:0 0 0 3px rgba(232,168,32,0.35); }
.newsletter-disclaimer { margin-top:14px; color:rgba(255,255,255,0.45); font-size:0.8rem; }
.newsletter-disclaimer a { color:rgba(255,255,255,0.65); text-decoration:underline; }

/* ── CONTACT ── */
#contact { background: var(--cream); }
.contact-grid { display:grid; grid-template-columns:1fr 1fr; gap:64px; }
.contact-info h2 { color:var(--navy); margin-bottom:16px; }
.contact-info p { margin-bottom:32px; }
.contact-items { display:flex; flex-direction:column; gap:18px; }
.contact-item { display:flex; align-items:flex-start; gap:14px; }
.contact-item-icon { width:42px; height:42px; min-width:42px; background:var(--navy); color:var(--gold); border-radius:10px; display:flex; align-items:center; justify-content:center; }
.contact-item-text strong { display:block; color:var(--navy); font-weight:600; font-size:0.9rem; }
.contact-item-text span { color:var(--gray); font-size:0.9rem; }
.contact-form-wrap { background:var(--white); border-radius:16px; padding:36px; box-shadow:var(--shadow); }
.contact-form-wrap h3 { color:var(--navy); margin-bottom:24px; }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:16px; margin-bottom:16px; }
.form-group { margin-bottom:16px; }
.form-group label { display:block; font-size:0.85rem; font-weight:500; color:var(--navy); margin-bottom:8px; }
.form-group input, .form-group select, .form-group textarea {
  width:100%; padding:12px 16px;
  border:1.5px solid #E2E8EF;
  border-radius:8px; font-family:'DM Sans',sans-serif; font-size:0.93rem;
  outline:none; transition:var(--transition);
  background:var(--white);
}
.form-group input:focus, .form-group select:focus, .form-group textarea:focus { border-color:var(--teal); box-shadow:0 0 0 3px rgba(13,110,138,0.1); }
.form-group textarea { resize:vertical; min-height:100px; }
.form-consent { display:flex; align-items:flex-start; gap:10px; margin:16px 0; }
.form-consent input { width:auto; margin-top:3px; }
.form-consent label { font-size:0.84rem; color:var(--gray); cursor:pointer; }
.form-consent a { color:var(--teal); }
@media(max-width:768px){ .contact-grid { grid-template-columns:1fr; } .form-row { grid-template-columns:1fr; } }

/* ── FOOTER ── */
#footer { background: var(--navy); color: rgba(255,255,255,0.65); padding:64px 24px 28px; }
.footer-inner {
  max-width:1180px; margin:0 auto;
  display:grid; grid-template-columns:2fr 1fr 1fr 1fr; gap:40px;
}
.footer-brand .nav-logo { margin-bottom:16px; }
.footer-brand p { font-size:0.9rem; line-height:1.75; max-width:280px; }
.footer-ojk {
  margin-top:20px; padding:12px 16px;
  border:1px solid rgba(255,255,255,0.12);
  border-radius:10px; font-size:0.78rem; color:rgba(255,255,255,0.5);
  line-height:1.5;
}
.footer-ojk strong { color:var(--gold); }
.footer-col h5 { color:var(--white); font-family:'DM Sans',sans-serif; font-size:0.85rem; font-weight:600; text-transform:uppercase; letter-spacing:0.1em; margin-bottom:18px; }
.footer-col ul { list-style:none; display:flex; flex-direction:column; gap:10px; }
.footer-col ul a { font-size:0.88rem; transition:var(--transition); }
.footer-col ul a:hover { color:var(--gold); }
.footer-bottom {
  max-width:1180px; margin:40px auto 0;
  padding-top:24px; border-top:1px solid rgba(255,255,255,0.08);
  display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:16px;
}
.footer-address { font-size:0.82rem; color:rgba(255,255,255,0.4); max-width:500px; }
.footer-copyright { font-size:0.82rem; color:rgba(255,255,255,0.4); }
@media(max-width:900px){ .footer-inner { grid-template-columns:1fr 1fr; } }
@media(max-width:520px){ .footer-inner { grid-template-columns:1fr; } }

/* ── UNSUBSCRIBE PAGE ── */
.page-hero { padding:140px 24px 80px; text-align:center; background:linear-gradient(135deg,#0D2B45,#0D4C6E); }
.page-hero h1 { color:var(--white); }
.page-hero p { color:rgba(255,255,255,0.65); max-width:520px; margin:12px auto; }
.page-content { padding:70px 24px; max-width:700px; margin:0 auto; }
.unsub-card { background:var(--white); border-radius:16px; padding:40px; box-shadow:var(--shadow); text-align:center; }
.unsub-card h3 { color:var(--navy); margin-bottom:12px; }
.unsub-card p { margin-bottom:28px; }
.success-msg { display:none; padding:18px; background:rgba(13,110,138,0.1); border:1px solid rgba(13,110,138,0.3); border-radius:10px; color:var(--teal); font-weight:500; margin-top:20px; }

/* ── PRIVACY/POLICY ── */
.policy-content { padding:60px 24px; max-width:860px; margin:0 auto; }
.policy-content h2 { color:var(--navy); margin:36px 0 14px; font-size:1.4rem; }
.policy-content h3 { color:var(--navy); margin:24px 0 10px; font-size:1.15rem; }
.policy-content p { margin-bottom:14px; font-size:0.97rem; }
.policy-content ul { padding-left:24px; margin-bottom:14px; }
.policy-content ul li { margin-bottom:6px; color:var(--gray); font-size:0.96rem; }
.policy-content .last-updated { color:var(--gray); font-size:0.85rem; margin-bottom:36px; }

/* ── ANIMATIONS ── */
.fade-up { opacity:0; transform:translateY(30px); transition:opacity 0.65s ease, transform 0.65s ease; }
.fade-up.visible { opacity:1; transform:translateY(0); }
