/* =====================================================
   Custom Style Nusadayana - Tambahkan di assets/css/nusadayana-custom.css
   atau tempel di bagian paling bawah assets/css/main.css
===================================================== */
:root {
  --accent-color: #ff9f5a;
  --heading-color: #0a0a0a;
  --nusa-red: #a90000;
  --nusa-orange: #ff5a00;
  --nusa-dark: #081018;
  --nusa-muted: #6b7280;
}

.nusadayana-page {
  letter-spacing: .4px;
}

.nusadayana-page .header {
  padding: 18px 0;
}

.nusadayana-page .header .logo img {
  max-height: 58px;
}

.nusadayana-page .header .logo .sitename {
  font-size: 24px;
  color: #fff;
}

.nusadayana-page .navmenu a,
.nusadayana-page .navmenu a:focus {
  text-transform: none;
  font-size: 15px;
  letter-spacing: 1px;
}

.nusadayana-page .cta-btn {
  background: rgba(255, 255, 255, .12);
  border-color: rgba(255, 255, 255, .55);
  border-radius: 999px;
  font-weight: 700;
}

.scrolled .header {
  --background-color: rgba(8, 16, 24, .92);
  backdrop-filter: blur(12px);
}

/* Hero */
.nusa-hero {
  min-height: 720px;
  padding-top: 120px;
}

.nusa-hero:before {
  background: linear-gradient(90deg, rgba(0, 0, 0, .68), rgba(0, 0, 0, .48)), rgba(0, 0, 0, .25);
}

.nusa-hero h2 {
  font-family: var(--heading-font);
  font-size: clamp(40px, 5vw, 68px);
  line-height: 1.18;
  letter-spacing: 3px;
  text-transform: none;
  max-width: 900px;
}

.nusa-hero p {
  max-width: 900px;
  color: rgba(255, 255, 255, .92);
  font-size: clamp(16px, 1.5vw, 22px);
  line-height: 1.7;
}

.hero-badge {
  display: inline-flex;
  padding: 9px 18px;
  margin-bottom: 18px;
  border: 1px solid rgba(255, 255, 255, .3);
  border-radius: 999px;
  color: #fff;
  background: rgba(255, 255, 255, .12);
  backdrop-filter: blur(10px);
  font-weight: 700;
}

.nusa-hero .btn-get-started,
.btn-whatsapp,
.btn-contact {
  min-width: 190px;
  text-align: center;
  border-radius: 999px;
  font-weight: 800;
  letter-spacing: .8px;
  box-shadow: 0 12px 28px rgba(255, 51, 19, .25);
}

.nusa-hero .btn-watch-video {
  min-width: 190px;
  justify-content: center;
  color: #fff;
  padding: 10px 30px;
  border: 1px solid rgba(255, 255, 255, .7);
  border-radius: 999px;
  margin-left: 0;
  backdrop-filter: blur(8px);
}

.nusa-hero .btn-watch-video i {
  font-size: 20px;
}

/* Shared Title */
.section-title {
  text-align: center;
  padding-bottom: 45px;
}

.section-title p {
  text-transform: none;
  font-size: clamp(34px, 4vw, 46px);
  letter-spacing: 1px;
}

.section-title span {
  display: block;
  margin-top: 10px;
  color: var(--nusa-muted);
}

.section-title.text-white h2,
.section-title.text-white p,
.section-title.text-white span {
  color: #fff;
}

.section-heading-left span {
  display: inline-block;
  color: var(--accent-color);
  font-weight: 800;
  margin-bottom: 8px;
}

.section-heading-left h2 {
  font-size: clamp(34px, 4vw, 48px);
  font-weight: 900;
  color: #050505;
  margin-bottom: 22px;
}

/* About */
.nusa-about {
  padding: 86px 0 80px;
}

.nusa-about p {
  font-size: 18px;
  line-height: 1.65;
  color: #4b5563;
  margin-bottom: 18px;
}

.read-more-link {
  color: #111;
  font-weight: 700;
  text-decoration: underline;
}

.about-image-wrap {
  position: relative;
  padding: 0 28px 34px 0;
}

.about-image-wrap img {
  position: relative;
  width: 100%;
  min-height: 450px;
  object-fit: cover;
  border-radius: 18px;
  z-index: 2;
  box-shadow: 0 26px 60px rgba(0, 0, 0, .14);
}

.about-shape {
  position: absolute;
  right: 0;
  bottom: 0;
  width: 88%;
  height: 88%;
  background: linear-gradient(135deg, var(--accent-color), var(--nusa-orange));
  border-radius: 18px 18px 18px 28px;
  z-index: 1;
}

/* Vitality */
.nusa-vitality {
  position: relative;
  padding: 0 0 90px;
  background: linear-gradient(180deg, #fff 0 105px, var(--nusa-orange) 105px 100%);
}

.stats-panel {
  background: var(--nusa-red);
  color: #fff;
  border-radius: 0 0 20px 20px;
  padding: 58px 90px;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 34px;
  box-shadow: 0 20px 45px rgba(169, 0, 0, .18);
}

.stats-box {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 24px;
}

.stats-box i {
  font-size: 78px;
  line-height: 1;
}

.stats-box strong {
  display: block;
  font-size: 58px;
  line-height: .95;
  font-weight: 900;
}

.stats-box span {
  display: block;
  font-size: 18px;
  font-weight: 800;
}

.vitality-content {
  max-width: 1060px;
  margin: 70px auto 0;
  text-align: center;
  color: #fff;
}

.vitality-content h2 {
  color: #fff;
  font-size: clamp(30px, 4vw, 44px);
  line-height: 1.25;
  font-weight: 900;
  margin-bottom: 28px;
}

.vitality-content p {
  font-size: 19px;
  line-height: 1.55;
  margin-bottom: 18px;
}

/* Process */
.nusa-process {
  background: #fff;
  padding-top: 82px;
}

.process-item {
  display: grid;
  grid-template-columns: 150px 1fr;
  gap: 24px;
  align-items: center;
  padding: 18px;
  border-radius: 22px;
  transition: .3s;
}

.process-item:hover {
  transform: translateY(-6px);
  box-shadow: 0 24px 60px rgba(15, 23, 42, .08);
}

.process-img {
  position: relative;
  border-radius: 14px;
  overflow: hidden;
  box-shadow: 9px 9px 0 var(--accent-color), 15px 15px 0 #ffd600;
}

.process-img img {
  width: 100%;
  height: 150px;
  object-fit: cover;
  filter: saturate(1.05);
}

.process-img span {
  position: absolute;
  left: 10px;
  top: -4px;
  font-size: 54px;
  font-weight: 300;
  color: rgba(0, 0, 0, .28);
  z-index: 2;
}

.process-item h3 {
  font-size: 20px;
  font-weight: 900;
  color: #030303;
  margin-bottom: 8px;
}

.process-item p {
  color: #4b5563;
  line-height: 1.58;
  margin: 0;
}

/* CTA */
.nusa-cta {
  position: relative;
  padding: 80px 0;
  min-height: 420px;
  display: flex;
  align-items: center;
}

.nusa-cta img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: brightness(.42);
}

.cta-card {
  position: relative;
  max-width: 980px;
  margin: auto;
  padding: 58px 90px;
  border-radius: 18px;
  background: linear-gradient(135deg, var(--accent-color), #ff5a00);
  text-align: center;
  box-shadow: 0 30px 80px rgba(0, 0, 0, .3);
}

.cta-card h2 {
  color: #fff;
  font-size: clamp(26px, 3vw, 34px);
  line-height: 1.35;
  font-weight: 900;
}

.btn-whatsapp,
.btn-contact {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 14px 34px;
  color: #fff;
  text-transform: uppercase;
  font-size: 14px;
}

.btn-whatsapp {
  background: #a90000;
}

.btn-contact {
  background: rgba(255, 255, 255, .18);
}

.btn-whatsapp:hover,
.btn-contact:hover {
  color: #fff;
  transform: translateY(-3px);
}

/* Portfolio */
.nusa-portfolio {
  background: #fff;
}

.portfolio-card {
  border-radius: 16px;
  overflow: hidden;
  background: #f08a2a;
  aspect-ratio: 1 / 1;
  box-shadow: 0 14px 36px rgba(15, 23, 42, .08);
}

.portfolio-card img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: .45s;
}

.portfolio-card:hover img {
  transform: scale(1.08);
}

/* Certification */
.nusa-certification {
  background: #fff;
  padding: 80px 0;
}

.cert-card {
  text-align: center;
  padding: 28px;
}

.cert-card i {
  display: inline-flex;
  width: 160px;
  height: 160px;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  font-size: 86px;
  color: var(--accent-color);
  background: #fff6f3;
  margin-bottom: 22px;
}

.cert-card h3 {
  font-size: 28px;
  color: #555;
  font-weight: 900;
}

/* Stories */
.nusa-stories {
  background: var(--nusa-red);
  padding: 78px 0;
}

.story-card {
  height: 100%;
  background: #fff;
  border-radius: 14px;
  overflow: hidden;
  box-shadow: 0 18px 60px rgba(0, 0, 0, .16);
}

.story-img {
  position: relative;
  height: 250px;
  overflow: hidden;
}

.story-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.story-img span {
  position: absolute;
  right: 18px;
  top: 18px;
  padding: 7px 18px;
  background: var(--accent-color);
  color: #fff;
  border-radius: 999px;
  text-transform: uppercase;
  font-size: 12px;
  font-weight: 800;
}

.story-body {
  padding: 30px 28px;
}

.story-body h3 {
  color: #0a0a0a;
  font-size: 22px;
  font-weight: 900;
  line-height: 1.22;
  margin-bottom: 22px;
}

.story-body p {
  color: #667085;
  line-height: 1.75;
  margin-bottom: 25px;
}

.story-body a {
  color: var(--accent-color);
  font-weight: 800;
  text-transform: uppercase;
  font-size: 13px;
}

.story-meta {
  border-top: 1px solid #eef2f7;
  padding: 14px 28px;
  color: #9aa4b2;
  font-size: 13px;
}

/* Contact */
.nusa-contact {
  background: #fff;
  padding: 82px 0;
}

.contact-form-card h3 {
  font-size: 24px;
  font-weight: 900;
  margin-bottom: 24px;
}

.contact-form-card label {
  display: block;
  margin: 12px 0 6px;
  color: #6b7280;
  font-size: 13px;
  letter-spacing: .8px;
}

.contact-form-card label b {
  color: var(--accent-color);
}

.contact-form-card input,
.contact-form-card textarea {
  width: 100%;
  border: 1px solid #a90000;
  border-radius: 5px;
  padding: 12px 14px;
  background: #fff;
  outline: none;
  transition: .3s;
}

.contact-form-card input:focus,
.contact-form-card textarea:focus {
  border-color: var(--accent-color);
  box-shadow: 0 0 0 4px rgba(255, 51, 19, .1);
}

.contact-form-card button {
  margin-top: 14px;
  min-width: 170px;
  border: 0;
  border-radius: 999px;
  background: #a90000;
  color: #fff;
  padding: 12px 24px;
  font-weight: 800;
}

.map-card {
  height: 470px;
  border-radius: 12px;
  overflow: hidden;
  box-shadow: 0 16px 45px rgba(15, 23, 42, .1);
}

.map-card iframe {
  width: 100%;
  height: 100%;
  border: 0;
}

/* Floating WA */
.floating-wa {
  position: fixed;
  right: 42px;
  bottom: 42px;
  z-index: 99998;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 12px 34px;
  border-radius: 999px;
  color: #fff;
  background: rgba(169, 0, 0, .78);
  backdrop-filter: blur(10px);
  font-weight: 800;
  letter-spacing: .6px;
  box-shadow: 0 16px 35px rgba(169, 0, 0, .28);
}

.floating-wa:hover {
  color: #fff;
  background: var(--accent-color);
}

.nusa-footer {
  background: #081018;
}

@media (max-width: 991px) {
  .nusa-hero { min-height: 640px; }
  .stats-panel { grid-template-columns: 1fr; padding: 42px 32px; border-radius: 18px; }
  .stats-box { justify-content: flex-start; }
  .process-item { grid-template-columns: 120px 1fr; }
  .process-img img { height: 120px; }
  .cta-card { padding: 42px 26px; }
  .about-image-wrap img { min-height: 340px; }
}

@media (max-width: 575px) {
  .nusa-hero h2 { letter-spacing: 1px; }
  .nusa-hero .btn-get-started, .nusa-hero .btn-watch-video { width: 100%; }
  .nusa-about p, .vitality-content p { font-size: 16px; }
  .process-item { grid-template-columns: 1fr; }
  .process-img { max-width: 180px; }
  .stats-box strong { font-size: 44px; }
  .stats-box i { font-size: 58px; }
  .floating-wa { right: 18px; bottom: 18px; padding: 10px 20px; }
}

/* =====================================================
   Nusadayana Modern Refresh V2
   Tempel di paling bawah main.css ATAU pakai sebagai assets/css/nusadayana-modern.css
   Nuansa: modern premium, navy-teal-coral, glassmorphism, soft motion
===================================================== */
:root {
  --accent-color: #ff9f5a;
  --heading-color: #102033;
  --nusa-red: #a90000;
  --nusa-orange: #ff5a00;
  --nusa-dark: #07111f;
  --nusa-deep: #102033;
  --nusa-teal: #16b8a6;
  --nusa-mint: #ddfff8;
  --nusa-cream: #fff7ef;
  --nusa-soft: #f7fafc;
  --nusa-muted: #667085;
  --nusa-line: rgba(16, 32, 51, .1);
  --nusa-shadow: 0 24px 70px rgba(7, 17, 31, .12);
}

body.nusadayana-page {
  background:
    radial-gradient(circle at top left, rgba(22, 184, 166, .11), transparent 34rem),
    radial-gradient(circle at 90% 18%, rgba(255, 107, 53, .1), transparent 28rem),
    #ffffff;
  color: #344054;
}

.nusadayana-page .header {
  padding: 16px 0;
  background: rgba(7, 17, 31, .22);
  backdrop-filter: blur(18px);
  border-bottom: 1px solid rgba(255, 255, 255, .08);
}

.scrolled .header {
  --background-color: rgba(255, 255, 255, .78);
  background: rgba(255, 255, 255, .78) !important;
  backdrop-filter: blur(22px);
  border-bottom: 1px solid rgba(16, 32, 51, .08);
}

.scrolled .header .logo .sitename,
.scrolled .navmenu a,
.scrolled .navmenu a:focus {
  color: #102033;
}

.scrolled .header .cta-btn {
  color: #fff;
  border-color: transparent;
  background: linear-gradient(135deg, var(--nusa-orange), var(--accent-color));
}

.nusadayana-page .navmenu a,
.nusadayana-page .navmenu a:focus {
  letter-spacing: .5px;
  font-weight: 700;
}

.nusadayana-page .navmenu>ul>li>a:before {
  height: 3px;
  bottom: -10px;
  border-radius: 99px;
  background: linear-gradient(90deg, var(--nusa-orange), var(--accent-color));
}

.nusadayana-page .cta-btn,
.nusa-hero .btn-get-started,
.btn-whatsapp,
.btn-contact,
.contact-form-card button {
  position: relative;
  overflow: hidden;
}

.nusadayana-page .cta-btn:before,
.nusa-hero .btn-get-started:before,
.btn-whatsapp:before,
.btn-contact:before,
.contact-form-card button:before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(120deg, transparent 0%, rgba(255,255,255,.45) 35%, transparent 70%);
  transform: translateX(-120%);
  transition: .65s ease;
}

.nusadayana-page .cta-btn:hover:before,
.nusa-hero .btn-get-started:hover:before,
.btn-whatsapp:hover:before,
.btn-contact:hover:before,
.contact-form-card button:hover:before {
  transform: translateX(120%);
}

/* HERO MODERN */
.nusa-hero {
  min-height: 760px;
  isolation: isolate;
}

.nusa-hero:before {
  background:
    linear-gradient(115deg, rgba(7, 17, 31, .84), rgba(7, 17, 31, .58) 44%, rgba(22, 184, 166, .18)),
    radial-gradient(circle at 30% 35%, rgba(255, 107, 53, .26), transparent 22rem),
    radial-gradient(circle at 78% 55%, rgba(22, 184, 166, .22), transparent 25rem);
}

.nusa-hero:after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 2;
  pointer-events: none;
  background-image:
    linear-gradient(rgba(255,255,255,.045) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.045) 1px, transparent 1px);
  background-size: 54px 54px;
  mask-image: linear-gradient(to bottom, rgba(0,0,0,.8), transparent 82%);
  animation: nusaGridMove 18s linear infinite;
}

@keyframes nusaGridMove {
  from { background-position: 0 0; }
  to { background-position: 54px 54px; }
}

.nusa-hero img {
  filter: grayscale(.15) contrast(1.08) saturate(.92);
  transform: scale(1.02);
}

.hero-badge {
  color: #d8fffa;
  border-color: rgba(216, 255, 250, .28);
  background: rgba(255, 255, 255, .08);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.22), 0 16px 45px rgba(0,0,0,.12);
}

.nusa-hero h2 {
  letter-spacing: -1.6px;
  text-transform: none;
  text-shadow: 0 16px 40px rgba(0, 0, 0, .32);
}

.nusa-hero p {
  max-width: 820px;
  color: rgba(255, 255, 255, .82);
}

.nusa-hero .btn-get-started {
  border: 0;
  background: linear-gradient(135deg, var(--accent-color), #ff7a1a);
  box-shadow: 0 18px 45px rgba(255, 107, 53, .33);
}

.nusa-hero .btn-watch-video {
  background: rgba(255, 255, 255, .1);
  border-color: rgba(255, 255, 255, .26);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.25), 0 18px 45px rgba(0,0,0,.18);
  transition: .35s ease;
}

.nusa-hero .btn-watch-video:hover {
  transform: translateY(-4px);
  background: rgba(22, 184, 166, .22);
  border-color: rgba(22, 184, 166, .55);
}

/* SECTION STYLE */
.section-title h2,
.section-heading-left span {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  color: var(--nusa-orange);
  font-weight: 900;
  letter-spacing: 1.4px;
}

.section-title h2::after {
  background: linear-gradient(90deg, var(--nusa-orange), var(--accent-color));
}

.section-title p,
.section-heading-left h2 {
  color: var(--nusa-deep);
  letter-spacing: -1px;
}

.nusa-about,
.nusa-process,
.nusa-portfolio,
.nusa-contact {
  background: linear-gradient(180deg, #fff, #fbfdff);
}

.about-image-wrap {
  padding: 18px;
  border-radius: 34px;
  background: rgba(255, 255, 255, .72);
  box-shadow: var(--nusa-shadow);
  border: 1px solid rgba(16, 32, 51, .08);
  backdrop-filter: blur(12px);
}

.about-image-wrap img {
  border-radius: 28px;
  box-shadow: none;
}

.about-shape {
  right: -16px;
  bottom: -16px;
  width: 54%;
  height: 62%;
  border-radius: 34px;
  background: linear-gradient(135deg, var(--nusa-orange), var(--accent-color));
  filter: blur(.2px);
}

.about-image-wrap:before {
  content: "";
  position: absolute;
  left: -22px;
  top: 36px;
  width: 120px;
  height: 120px;
  border-radius: 999px;
  background: linear-gradient(135deg, rgba(22, 184, 166, .18), rgba(255, 107, 53, .16));
  animation: nusaFloat 5.5s ease-in-out infinite;
}

@keyframes nusaFloat {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-16px); }
}

.read-more-link {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  color: var(--nusa-deep);
  text-decoration: none;
  border-bottom: 2px solid var(--accent-color);
}

.read-more-link:after {
  content: "→";
  transition: .3s ease;
}

.read-more-link:hover:after {
  transform: translateX(6px);
}

/* STATS + VITALITY */
.nusa-vitality {
  background:
    linear-gradient(180deg, #ffffff 0 95px, #0b1728 95px 100%);
  overflow: hidden;
}

.nusa-vitality:before {
  content: "";
  position: absolute;
  width: 520px;
  height: 520px;
  right: -160px;
  bottom: -160px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(22,184,166,.28), transparent 68%);
  pointer-events: none;
}

.stats-panel {
  background: rgba(16, 32, 51, .94);
  border: 1px solid rgba(255, 255, 255, .1);
  border-radius: 28px;
  padding: 46px 70px;
  box-shadow: 0 30px 80px rgba(7, 17, 31, .22);
  backdrop-filter: blur(14px);
}

.stats-box {
  justify-content: flex-start;
  padding: 18px;
  border-radius: 24px;
  transition: .35s ease;
}

.stats-box:hover {
  background: rgba(255,255,255,.07);
  transform: translateY(-7px);
}

.stats-box i {
  font-size: 64px;
  color: var(--nusa-orange);
  filter: drop-shadow(0 0 18px rgba(22, 184, 166, .28));
}

.stats-box strong {
  font-size: 50px;
  background: linear-gradient(135deg, #fff, #d8fffa);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}

.vitality-content h2 {
  color: #ffffff;
  letter-spacing: -1px;
}

.vitality-content p {
  color: rgba(255, 255, 255, .78);
}

/* PROCESS MODERN CARD */
.process-item {
  grid-template-columns: 156px 1fr;
  padding: 18px;
  border: 1px solid var(--nusa-line);
  background: rgba(255, 255, 255, .82);
  box-shadow: 0 14px 45px rgba(16, 32, 51, .055);
  backdrop-filter: blur(10px);
}

.process-item:hover {
  transform: translateY(-9px);
  border-color: rgba(22, 184, 166, .28);
  box-shadow: 0 28px 75px rgba(16, 32, 51, .12);
}

.process-img {
  border-radius: 24px;
  box-shadow: none;
}

.process-img:after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(22,184,166,.35), rgba(255,107,53,.2));
  opacity: .75;
}

.process-img span {
  color: rgba(255, 255, 255, .86);
  font-weight: 900;
  z-index: 3;
  text-shadow: 0 10px 30px rgba(0,0,0,.28);
}

.process-item h3 {
  color: var(--nusa-deep);
  letter-spacing: -.2px;
}

.process-item p {
  color: #5d6b7c;
}

/* CTA */
.nusa-cta:before {
  background: linear-gradient(115deg, rgba(7,17,31,.92), rgba(7,17,31,.58));
}

.cta-card {
  border-radius: 34px;
  background:
    radial-gradient(circle at top left, rgba(255,255,255,.32), transparent 15rem),
    linear-gradient(135deg, rgba(22, 184, 166, .96), rgba(255, 107, 53, .96));
  border: 1px solid rgba(255,255,255,.22);
  box-shadow: 0 35px 100px rgba(0,0,0,.34);
}

.btn-whatsapp {
  background: rgba(7, 17, 31, .72);
}

.btn-contact {
  background: rgba(255,255,255,.2);
  border: 1px solid rgba(255,255,255,.24);
}

/* PORTFOLIO */
.portfolio-card {
  border-radius: 28px;
  background: linear-gradient(135deg, var(--nusa-cream), var(--nusa-mint));
  box-shadow: 0 20px 60px rgba(16, 32, 51, .1);
  border: 1px solid rgba(16, 32, 51, .06);
  position: relative;
}



.portfolio-card:hover:after {
  opacity: 1;
  transform: translateY(0);
}

.portfolio-card:hover img {
  transform: scale(1.08) rotate(.8deg);
}

/* CERT */
.cert-card {
  border-radius: 30px;
  background: #fff;
  border: 1px solid var(--nusa-line);
  box-shadow: 0 18px 55px rgba(16,32,51,.06);
  transition: .35s ease;
}

.cert-card:hover {
  transform: translateY(-8px);
  box-shadow: 0 28px 75px rgba(16,32,51,.12);
}

.cert-card i {
  color: #fff;
  background: linear-gradient(135deg, var(--nusa-orange), var(--accent-color));
  box-shadow: 0 18px 45px rgba(22, 184, 166, .2);
}

.cert-card h3 {
  color: var(--nusa-deep);
}

/* STORIES */
.nusa-stories {
  background:
    radial-gradient(circle at 10% 20%, rgba(255, 107, 53, .18), transparent 24rem),
    linear-gradient(135deg, #07111f, #102033);
}

.story-card {
  border-radius: 26px;
  box-shadow: 0 24px 70px rgba(0, 0, 0, .22);
  border: 1px solid rgba(255,255,255,.08);
  transition: .35s ease;
}

.story-card:hover {
  transform: translateY(-10px);
}

.story-img span {
  background: linear-gradient(135deg, var(--nusa-orange), var(--accent-color));
}

.story-img img {
  transition: .45s ease;
}

.story-card:hover .story-img img {
  transform: scale(1.07);
}

/* CONTACT */
.contact-form-card,
.map-card {
  padding: 30px;
  border-radius: 30px;
  background: #fff;
  border: 1px solid var(--nusa-line);
  box-shadow: 0 20px 60px rgba(16,32,51,.08);
}

.contact-form-card input,
.contact-form-card textarea {
  border: 1px solid rgba(16, 32, 51, .14);
  border-radius: 16px;
  background: #fbfdff;
}

.contact-form-card input:focus,
.contact-form-card textarea:focus {
  border-color: var(--nusa-orange);
  box-shadow: 0 0 0 5px rgba(22, 184, 166, .12);
}

.contact-form-card button {
  background: linear-gradient(135deg, var(--nusa-orange), var(--accent-color));
  box-shadow: 0 18px 40px rgba(22, 184, 166, .18);
}

.map-card {
  padding: 10px;
}

.map-card iframe {
  border-radius: 22px;
}

/* FLOATING WA */
.floating-wa {
  background: linear-gradient(135deg, #22c55e, var(--nusa-orange));
  box-shadow: 0 18px 48px rgba(34, 197, 94, .24);
  animation: nusaPulse 2.4s infinite;
}

@keyframes nusaPulse {
  0%, 100% { transform: translateY(0); box-shadow: 0 18px 48px rgba(34,197,94,.24); }
  50% { transform: translateY(-4px); box-shadow: 0 24px 62px rgba(34,197,94,.34); }
}

.nusa-footer {
  background: linear-gradient(135deg, #07111f, #102033);
}

@media (max-width: 991px) {
  .stats-panel { padding: 28px; }
  .process-item { grid-template-columns: 132px 1fr; }
  .contact-form-card, .map-card { padding: 20px; }
}

@media (max-width: 575px) {
  .nusa-hero { min-height: 660px; }
  .nusa-hero h2 { letter-spacing: -.8px; }
  .stats-box { padding: 10px; }
  .process-item { grid-template-columns: 1fr; }
  .process-img { max-width: 100%; }
}

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: .01ms !important;
    animation-iteration-count: 1 !important;
    scroll-behavior: auto !important;
  }
}

/* =====================================================
   Final Theme Override - Request Barra
   Orange: #ff5a00
   Merah Maroon: #a90000
===================================================== */
:root {
  --accent-color: #ff5a00;
  --nusa-orange: #ff5a00;
  --nusa-red: #a90000;
}

.nusa-hero .btn-get-started,
.btn-contact,
.contact-form-card button,
.story-img span,
.cert-card i,
.cta-card,
.about-shape {
  background: linear-gradient(135deg, #ff5a00, #ff7a1a) !important;
}

.stats-panel,
.nusa-stories {
  background: #a90000 !important;
}

.btn-whatsapp,
.floating-wa {
  background: linear-gradient(135deg, #a90000, #7f0000) !important;
}

.nusa-vitality {
  background: linear-gradient(180deg, #fff 0 105px, #ff5a00 105px 100%) !important;
}

.nusa-hero:before {
  background:
    linear-gradient(90deg, rgba(0, 0, 0, .68), rgba(0, 0, 0, .48)),
    radial-gradient(circle at 30% 35%, rgba(255, 90, 0, .22), transparent 22rem),
    rgba(0, 0, 0, .25) !important;
}

.read-more-link,
.story-body a,
.section-heading-left span,
.section-title h2,
.contact-form-card label b {
  color: #ff5a00 !important;
}

.contact-form-card input:focus,
.contact-form-card textarea:focus {
  border-color: #ff5a00 !important;
  box-shadow: 0 0 0 4px rgba(255, 90, 0, .12) !important;
}
