
/*
====================================================

	KIBAKI Landing Page Styles
	Coming Soon / Pre-launch page

====================================================

	TOC

	1. PRIMARY STYLES
	2. COMMONS
	3. MAIN SECTION
		3a. Hero
		3b. Offer Box
		3c. Buttons
		3d. Countdown

====================================================
*/

/* ---------------------------------
1. PRIMARY STYLES
--------------------------------- */
@import url('https://fonts.googleapis.com/css2?family=Manrope:wght@200..800&display=swap');
html { font-size: 100%; height: 100%; width: 100%; overflow-x: hidden; margin: 0; padding: 0; touch-action: manipulation; }

body {
	font-size: 16px;
	font-family: 'Manrope', sans-serif;
	width: 100%;  margin: 0;
	font-weight: 400;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	word-wrap: break-word;
	overflow-x: hidden;
	color: #ececec;
	background: #0a0a0a;
}
.kbk-landing-main {
	padding: 50px 0 0;
	text-align: center;
}
h1, h2, h3, h4, h5, h6, p, a, ul, span, li, img, input, button { margin: 0; padding: 0; }

h1, h2, h3, h4, h5, h6 { line-height: 1.5; font-weight: inherit; font-family: 'Manrope', sans-serif; }

p { line-height: 1.6; font-size: 1em; }

a, button { display: inline-block; text-decoration: none; color: inherit; transition: all .25s; }

li { list-style: none; }

img { max-width: 100%; }

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


/* ---------------------------------
2. COMMONS
--------------------------------- */

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

.display-table { display: table; height: 100%; width: 100%; }

.display-table-cell { display: table-cell; vertical-align: middle; }

.font-white { color: #fff; }


/* ---------------------------------
3a. MAIN SECTION — Hero
--------------------------------- */

.main-area-wrapper { height: 100%; }

.main-area {
	position: relative;
	z-index: 1;
	min-height: 100vh;
	padding: 60px 20px;
	display: flex;
	align-items: center;
	justify-content: center;
	background: #0a0a0a;
}

.display-table-cell img {
	max-width: 200px;
	width: auto;
	display: block;
	margin: 0 auto 32px;
}

.kbk-hero-title {
	font-size: 1.7em;
	font-weight: 700;
	color: #eee;
	line-height: 1.2;
}

.kbk-launch-label {
	font-size: .95em;
	color: rgba(255,255,255,.45);
	margin-bottom: 20px;
	letter-spacing: .04em;
}


/* ---------------------------------
3b. Founding Member Offer Box
--------------------------------- */

.kbk-offer-box {
	display: inline-block;
	max-width: 420px;
	width: 100%;
	border: 1px solid rgba(255,255,255,.18);
	border-radius: 14px;
	padding: 18px 22px 22px;
	margin-bottom: 22px;
	background: rgba(255,255,255,.04);
	text-align: left;
}

.kbk-offer-heading {
	font-size: 1.05em;
	font-weight: 700;
	color: #fff;
	margin-bottom: 15px;
}

.kbk-offer-sub {
	font-size: .88em;
	color: rgba(255,255,255,.65);
	margin-bottom: 12px;
}

.kbk-offer-list {
	list-style: none;
	margin: 0 0 15px;
	padding: 0;
}

.kbk-offer-list li {
	display: block;
	font-size: .93em;
	color: rgba(255,255,255,.85);
	padding: 5px 0;
	letter-spacing: .01em;
}

.kbk-offer-list li::before { content: none; }


/* ---------------------------------
3c. Buttons
--------------------------------- */

.kbk-btn {
	display: inline-block;
	padding: 13px 28px;
	border-radius: 50px;
	font-size: .93em;
	font-weight: 600;
	cursor: pointer;
	transition: all .25s;
	letter-spacing: .02em;
	border: 2px solid transparent;
	text-decoration: none;
}

.kbk-btn--primary {
	background: #ff5722;
	color: #fff;
	border-color: #ff5722;
	width: 100%;
	text-align: center;
	font-weight: 700;
}

.kbk-btn--primary:hover,
.kbk-btn--primary:focus {
	background: #e64a19;
	border-color: #e64a19;
	color: #fff;
}

.kbk-btn--ghost {
	background: transparent;
	color: rgba(255,255,255,.75);
	border: 1px solid rgba(255,255,255,.25);
	padding: 11px 24px;
}

.kbk-btn--ghost:hover,
.kbk-btn--ghost:focus {
	border-color: rgba(255,255,255,.6);
	color: #fff;
}

.kbk-or {
	font-size: .85em;
	color: rgba(255,255,255,.35);
	margin: 0 0 14px;
	text-transform: lowercase;
}


/* ---------------------------------
3d. Countdown
--------------------------------- */

.kbk-countdown-wrap {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 12px;
	margin-top: 26px;
}

.kbk-countdown-icon {
	font-size: 1.3em;
	line-height: 1;
}

#normal-countdown { text-align: center; display: flex; gap: 4px; align-items: center; }

#normal-countdown .time-sec {
	position: relative;
	display: inline-flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	margin: 0 6px;
	height: 64px;
	width: 64px;
	border-radius: 10px;
	background: #f3f3f3;
}

#normal-countdown .time-sec .main-time {
	font-weight: 700;
	font-size: 1.7em;
	color: #ff5722;
	line-height: 1;
	margin-bottom: 4px;
}
.kbk-landing-logo-link {
	margin-bottom: 50px;
}
#normal-countdown .time-sec span {
	font-size: .65em;
	font-weight: 600;
	color: #0a0a0a !important;
	letter-spacing: .05em;
}


/* ---------------------------------
4. Modal
--------------------------------- */

.kbk-modal {
	position: fixed;
	inset: 0;
	z-index: 9999;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 16px;
}

.kbk-modal__overlay {
	position: absolute;
	inset: 0;
	background: rgba(0,0,0,.75);
	backdrop-filter: blur(4px);
}

.kbk-modal__box {
	position: relative;
	z-index: 1;
	background: #141414;
	border: 1px solid rgba(255,255,255,.14);
	border-radius: 16px;
	padding: 36px 32px 32px;
	width: 100%;
	max-width: 440px;
	text-align: left;
}

.kbk-modal__close {
	position: absolute;
	top: 14px;
	right: 16px;
	background: none;
	border: none;
	color: rgba(255,255,255,.45);
	font-size: 1.1em;
	cursor: pointer;
	line-height: 1;
	padding: 4px 6px;
	transition: color .2s;
}
.kbk-modal__close:hover { color: #fff; }

.kbk-modal__title {
	font-size: 1.2em;
	font-weight: 700;
	color: #fff;
	margin-bottom: 8px;
}

.kbk-modal__subtitle {
	font-size: .88em;
	color: rgba(255,255,255,.55);
	margin-bottom: 24px;
	line-height: 1.5;
}

/* Form rows */
.kbk-form__row {
	margin-bottom: 14px;
}

.kbk-form__row label {
	display: block;
	font-size: .83em;
	color: rgba(255,255,255,.6);
	margin-bottom: 6px;
	font-weight: 600;
	letter-spacing: .02em;
}

.kbk-form__row input[type="text"],
.kbk-form__row input[type="email"] {
	width: 100%;
	background: rgba(255,255,255,.06);
	border: 1px solid rgba(255,255,255,.14);
	border-radius: 8px;
	padding: 11px 14px;
	color: #fff;
	font-size: .93em;
	font-family: inherit;
	outline: none;
	transition: border-color .2s;
}

.kbk-form__row input:focus {
	border-color: rgba(255,87,34,.6);
}

.kbk-form__row input::placeholder {
	color: rgba(255,255,255,.25);
}

.kbk-form__feedback {
	font-size: .85em;
	min-height: 20px;
	margin: 10px 0 14px;
	line-height: 1.4;
}
.ligal-links ul {
  display: flex;
  justify-content: center;
  gap: 15px;
  font-size: 10px;
  color: #eee;
  margin-top: 15px;
}
.kbk-form__feedback.is-error   { color: #ff6b6b; }
.kbk-form__feedback.is-success { color: #69db7c; }

.kbk-modal__submit {
	width: 100%;
	text-align: center;
	font-size: .95em;
}
.ligal-links {
  border-top: 1px solid #151515;
  margin: 50px 0 15px;
}
/* Success state */
.kbk-modal__success {
	text-align: center;
	padding: 8px 0;
}

.kbk-modal__success-icon {
	font-size: 2.8em;
	margin-bottom: 14px;
}

.kbk-modal__success h2 {
	font-size: 1.3em;
	font-weight: 700;
	color: #fff;
	margin-bottom: 10px;
}

.kbk-modal__success p {
	font-size: .9em;
	color: rgba(255,255,255,.6);
	line-height: 1.6;
}

/* Prevent background scroll when modal is open */
body.kbk-modal-open { overflow: hidden; }


/* ---------------------------------
Responsive
--------------------------------- */

@media (max-width: 480px) {
	.kbk-hero-title { font-size: 1.65em; }

	.kbk-offer-box { padding: 22px 20px 24px; }

	#normal-countdown .time-sec { height: 56px; width: 56px; margin: 0 4px; }
	#normal-countdown .time-sec .main-time { font-size: 1.4em; }
	.kbk-offer-box { max-width: 95%;}
}

@media (max-width: 360px) {
	#normal-countdown .time-sec { height: 50px; width: 50px; margin: 0 3px; }
	#normal-countdown .time-sec .main-time { font-size: 1.2em; }
}
