    :root {
    	--glass-bg: rgba(17, 17, 20, 0.55);
    	--glass-border: rgba(255, 255, 255, 0.14);
    	--muted: rgba(255, 255, 255, 0.65);
    }

    html,
    body {
    	height: 100%;
    }

    body {
    	margin: 0;
    	font-family: system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
    	background: #0b0c10;
    	overflow: hidden;
    }

    /* ============ BACKGROUND SLIDER ============ */
    .bg-slider {
    	position: fixed;
    	inset: 0;
    	z-index: 0;
    	overflow: hidden;
    	background: #0b0c10;
    }

    .bg-slide {
    	position: absolute;
    	inset: 0;
    	background-size: cover;
    	background-position: center;
    	opacity: 0;
    	transform: scale(1.03);
    	transition: opacity .9s ease, transform 6s ease;
    	filter: saturate(1.05);
    }

    .bg-slide.active {
    	opacity: 1;
    	transform: scale(1.0);
    }

    /* overlay gelap biar teks kebaca */
    .bg-overlay {
    	position: absolute;
    	inset: 0;
    	background:
    		radial-gradient(800px 500px at 70% 40%, rgba(0, 0, 0, .25), rgba(0, 0, 0, .65)),
    		linear-gradient(90deg, rgba(0, 0, 0, .70) 0%, rgba(0, 0, 0, .40) 55%, rgba(0, 0, 0, .65) 100%);
    }

    /* ============ LAYOUT ============ */
    .page {
    	position: relative;
    	z-index: 1;
    	height: 100vh;
    	width: 100%;
    	display: flex;
    	align-items: center;
    }

    .container-wide {
    	width: min(1320px, 200vw);
    	margin: 0 auto;
    }

    .brand-row {
    	position: absolute;
    	top: 22px;
    	left: 0;
    	right: 0;
    	z-index: 2;
    }

    .brand {
    	display: flex;
    	align-items: center;
    	gap: 12px;
    	color: #fff;
    	font-weight: 600;
    	letter-spacing: .3px;
    }

    .brand img {
    	/* width: 42px;
      height: 42px; */
    	object-fit: contain;
    }

    .location-pill {
    	display: inline-flex;
    	align-items: center;
    	gap: 8px;
    	color: rgba(255, 255, 255, .9);
    	font-weight: 600;
    	padding: 8px 12px;
    	border-radius: 999px;
    	background: rgba(0, 0, 0, .35);
    	border: 1px solid rgba(255, 255, 255, .10);
    	backdrop-filter: blur(8px);
    }

    .left-hero h1 {
    	color: #fff;
    	font-weight: 800;
    	line-height: 1.02;
    	letter-spacing: -0.5px;
    	font-size: clamp(38px, 4vw, 64px);
    	margin-bottom: 18px;
    }

    .left-hero p.lead {
    	margin-top: 80px;
    	color: #FFFFFF;
    	max-width: 520px;
    	font-size: 24px;
    	font-weight: 400;
    	margin-bottom: 22px;
    }

    .feature-list {
    	list-style: none;
    	padding: 0;
    	margin: 0;
    	display: grid;
    	gap: 12px;
    	max-width: 520px;
    }

    .feature-list li {
    	display: flex;
    	align-items: flex-start;
    	gap: 10px;
    	color: rgba(255, 255, 255, .85);
    	font-size: 0.98rem;
    }

    .feature-list .check {
    	width: 22px;
    	height: 22px;
    	display: inline-flex;
    	align-items: center;
    	justify-content: center;
    	border-radius: 999px;
    	background: rgba(0, 255, 180, .12);
    	border: 1px solid rgba(0, 255, 180, .25);
    	color: #2cffc7;
    	flex: 0 0 auto;
    	margin-top: 1px;
    }

    /* slider dots kiri bawah */
    .dots {
    	position: absolute;
    	left: 90px;
    	bottom: 100px;
    	display: flex;
    	gap: 10px;
    	z-index: 2;
    }

    .dot {
    	width: 10px;
    	height: 10px;
    	border-radius: 999px;
    	background: rgba(255, 255, 255, .35);
    	border: 1px solid rgba(255, 255, 255, .25);
    	cursor: pointer;
    	transition: transform .2s ease, background .2s ease;
    }

    .dot.active {
    	background: rgba(255, 255, 255, .95);
    	transform: scale(1.15);
    }

    /* ============ GLASS CARD ============ */
    .glass-card {
    	width: min(430px, 92vw);
    	height: 450px;
    	margin-left: auto;
    	padding: 26px 26px 18px;
    	border-radius: 18px;
    	background: var(--glass-bg);
    	border: 1px solid var(--glass-border);
    	backdrop-filter: blur(14px);
    	-webkit-backdrop-filter: blur(14px);
    	box-shadow: 0 18px 60px rgba(18, 18, 18, 0.5);
    	color: #fff;
    }

    .glass-card .content-center {
    	text-align: center;
    }

    .glass-card h2 {
    	font-size: 30px;
    	font-weight: 700;
    	letter-spacing: -.3px;
    	margin-bottom: 6px;
    }

    .glass-card .sub {
    	font-size: 14px;
    	color: #6B7280;
    	font-size: .95rem;
    	margin-bottom: 18px;
    }

    .form-label {
    	color: #6B7280;
    }

    .form-control {
    	border-radius: 14px;
    }

    .form-control,
    .input-group-text {
    	background: rgba(255, 255, 255, .06) !important;
    	border: 1px solid rgba(255, 255, 255, .12) !important;
    	color: #FFF !important;
    	font-size: 16px;
    }

    .form-control::placeholder {
    	color: rgba(255, 255, 255, .40);
    }

    .form-control:focus {
    	box-shadow: 0 0 0 .2rem rgba(13, 110, 253, .15);
    	border-color: rgba(13, 110, 253, .5) !important;
    }

    .btn-primary {
    	padding: 12px 14px;
    	font-weight: 700;
    	border-radius: 12px;
    }

    .btn-dark-soft {
    	background: rgba(255, 255, 255, .08);
    	border: 1px solid rgba(255, 255, 255, .12);
    	color: rgba(255, 255, 255, .9);
    	padding: 12px 14px;
    	border-radius: 12px;
    	font-weight: 700;
    }

    .btn-dark-soft:hover {
    	background: rgba(255, 255, 255, .12);
    	color: #fff;
    }

    .small-links a {
    	color: rgba(255, 255, 255, .65);
    	text-decoration: none;
    }

    .small-links a:hover {
    	color: #fff;
    	text-decoration: underline;
    }

    .footer-links {
    	display: flex;
    	justify-content: space-between;
    	align-items: center;
    	color: #6B7280;
    	font-size: 16px;
    	margin-top: 14px;
    	padding-top: 14px;
    	text-align: center;
    	margin-left: 200px;
    	/* border-top: 1px solid rgba(255,255,255,.10); */
    	gap: 10px;
    	flex-wrap: wrap;
    }

    .footer-links .version {
    	margin-left: 40px;
    	text-align: center;
    	font-size: 12px;
    }

    .dot2 {
    	margin-top: 14px;
    	width: 3px;
    	height: 3px;
    	border-radius: 999px;
    	background: rgba(255, 255, 255, .35);
    	border: 1px solid rgba(255, 255, 255, .25);
    	cursor: pointer;
    	align-items: center;
    }

    .password-field {
    	position: relative;
    }

    .password-field input {
    	padding-right: 45px;
    	border-radius: 14px;
    }

    .toggle-pass {
    	position: absolute;
    	right: 15px;
    	top: 50%;
    	transform: translateY(-50%);
    	cursor: pointer;
    	color: rgba(255, 255, 255, .6);
    	font-size: 18px;
    }

    .toggle-pass:hover {
    	color: #fff;
    }

    /* responsive: kalau layar kecil, card turun bawah */
    @media (max-width: 992px) {
    	body {
    		overflow: auto;
    	}

    	.page {
    		height: auto;
    		min-height: 100vh;
    		padding: 90px 0 40px;
    	}

    	.dots {
    		left: 24px;
    		bottom: 18px;
    	}
    }
