/* =========================================================
   Coming Soon — Personal Site (HTML/CSS/JS)
   Style vibe: modern-tech + retro-vintage accents
   Palette (inspired by your Alabao retro kit + tech accents)
   ========================================================= */

:root{
  --bg: #0b0f17;
  --bg2: #0f1626;
  --card: rgba(18, 24, 38, 0.72);
  --stroke: rgba(245, 233, 210, 0.16);

  --cream: #F5E9D2;
  --charcoal: #212121;
  --retro-red: #B13A30;
  --vintage-blue: #2A6FB2;
  --lettuce: #548C5B;
  --pineapple: #F7C045;

  --cyan: #35D2FF;
  --magenta: #FF4FD8;

  --text: rgba(245,233,210,0.92);
  --muted: rgba(245,233,210,0.68);

  --shadow: 0 20px 70px rgba(0,0,0,0.55);
  --radius: 22px;
  --radius2: 16px;

  --mono: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
  --sans: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, "Apple Color Emoji","Segoe UI Emoji";
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family: var(--sans);
  color: var(--text);
  background: radial-gradient(1200px 900px at 20% 10%, rgba(42,111,178,0.18), transparent 55%),
              radial-gradient(1100px 800px at 80% 20%, rgba(177,58,48,0.16), transparent 55%),
              linear-gradient(180deg, var(--bg), var(--bg2));
  overflow-x:hidden;
}

/* ---------------- Background layers ---------------- */
.bg{position:fixed; inset:0; z-index:-1; pointer-events:none;}
.bg__noise{
  position:absolute; inset:-30%;
  background-image:url("assets/noise.svg");
  opacity:0.14;
  mix-blend-mode:overlay;
  transform:rotate(2deg);
}
.bg__glow{
  position:absolute; inset:0;
  background:
    radial-gradient(800px 500px at 35% 25%, rgba(53,210,255,0.12), transparent 65%),
    radial-gradient(700px 500px at 70% 70%, rgba(255,79,216,0.10), transparent 65%),
    radial-gradient(900px 600px at 25% 80%, rgba(247,192,69,0.08), transparent 60%);
  filter: blur(10px);
  animation: breathe 8s ease-in-out infinite;
}
.bg__pattern{
  position:absolute; inset:0;
  background-image:url("assets/pattern.svg");
  opacity:0.09;
  transform: translate3d(0,0,0);
  animation: drift 18s linear infinite;
}
.bg__floaters{position:absolute; inset:0;}
.floater{
  position:absolute;
  width:48px; height:48px;
  fill: rgba(245,233,210,0.18);
  filter: drop-shadow(0 10px 25px rgba(0,0,0,0.35));
  animation: float 10s ease-in-out infinite;
}
.floater--a{left:8%; top:18%; transform:rotate(6deg);}
.floater--b{right:10%; top:32%; transform:rotate(-8deg); animation-delay:-2.5s;}
.floater--c{left:14%; bottom:18%; transform:rotate(-3deg); animation-delay:-4.2s;}

@keyframes float{
  0%,100%{transform:translateY(0) rotate(var(--r,0deg)); opacity:0.7}
  50%{transform:translateY(-18px) rotate(var(--r,0deg)); opacity:1}
}
@keyframes breathe{
  0%,100%{transform:scale(1)}
  50%{transform:scale(1.03)}
}
@keyframes drift{
  0%{background-position:0 0}
  100%{background-position:420px 260px}
}

/* ---------------- Layout ---------------- */
.topbar{
  max-width: 1100px;
  margin: 0 auto;
  padding: 22px 18px 10px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
}
.brand{
  display:flex;
  align-items:baseline;
  gap:10px;
  text-decoration:none;
  color:var(--text);
}
.brand__mark{
  width:30px; height:18px;
  display:flex;
  gap:6px;
  align-items:center;
}
.brand__dot{
  width:10px; height:10px;
  border-radius:999px;
  background: var(--cyan);
  box-shadow: 0 0 0 6px rgba(53,210,255,0.12);
}
.brand__dot--alt{
  background: var(--pineapple);
  box-shadow: 0 0 0 6px rgba(247,192,69,0.12);
}
.brand__text{
  font-weight: 800;
  letter-spacing: -0.02em;
  font-size: 18px;
}
.brand__tag{
  font-family: var(--mono);
  font-size: 12px;
  color: var(--muted);
}

.topbar__actions{display:flex; gap:10px; align-items:center;}

.wrap{
  max-width: 1100px;
  margin: 0 auto;
  padding: 12px 18px 80px;
  display:flex;
  align-items:flex-start;
  justify-content:center;
}

.card{
  width: min(980px, 100%);
  background: linear-gradient(180deg, rgba(245,233,210,0.06), rgba(245,233,210,0.02));
  border: 1px solid var(--stroke);
  box-shadow: var(--shadow);
  border-radius: var(--radius);
  overflow:hidden;
  position:relative;
}
.card::before{
  content:"";
  position:absolute;
  inset:-2px;
  background: radial-gradient(700px 280px at 30% 10%, rgba(53,210,255,0.14), transparent 60%),
              radial-gradient(700px 300px at 80% 30%, rgba(255,79,216,0.10), transparent 60%),
              radial-gradient(800px 320px at 60% 95%, rgba(177,58,48,0.11), transparent 70%);
  filter: blur(18px);
  opacity:0.9;
  pointer-events:none;
}
.card__header, .card__body, .card__footer{position:relative; z-index:1;}
.card__header{padding: 26px 22px 0;}
.card__body{padding: 18px 22px 26px;}
.card__footer{
  padding: 16px 22px;
  border-top:1px solid rgba(245,233,210,0.10);
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  flex-wrap:wrap;
  background: rgba(15,22,38,0.35);
}

.chip{
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding: 8px 12px;
  border-radius: 999px;
  border: 1px solid rgba(245,233,210,0.18);
  background: rgba(11,15,23,0.45);
  backdrop-filter: blur(10px);
}
.chip__dot{
  width:8px; height:8px;
  border-radius: 999px;
  background: var(--lettuce);
  box-shadow: 0 0 0 6px rgba(84,140,91,0.14);
}
.chip__text{
  font-family: var(--mono);
  font-size: 12px;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--cream);
}

.title{margin: 16px 0 0;}
.title__big{
  display:block;
  font-size: clamp(28px, 3.4vw, 44px);
  line-height:1.05;
  font-weight: 900;
  letter-spacing: -0.03em;
}
.title__sub{
  display:block;
  margin-top: 10px;
  max-width: 58ch;
  color: var(--muted);
  font-size: 15px;
  line-height:1.45;
}

.note{
  margin: 16px 0 20px;
  padding: 14px 14px;
  border-radius: var(--radius2);
  background: rgba(11,15,23,0.45);
  border: 1px dashed rgba(245,233,210,0.16);
}
.note__label{
  font-family: var(--mono);
  color: rgba(53,210,255,0.92);
  margin-right: 8px;
}
.note__text{color: var(--text);}

.countdown{
  padding: 16px;
  border-radius: var(--radius2);
  border: 1px solid rgba(245,233,210,0.14);
  background: rgba(18,24,38,0.50);
  backdrop-filter: blur(10px);
}
.countdown__grid{
  display:grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 12px;
}
.timebox{
  border-radius: 14px;
  border: 1px solid rgba(245,233,210,0.12);
  background: linear-gradient(180deg, rgba(11,15,23,0.65), rgba(11,15,23,0.38));
  padding: 14px 12px;
  text-align:center;
}
.timebox__num{
  font-family: var(--mono);
  font-size: clamp(22px, 2.6vw, 34px);
  font-weight: 900;
  letter-spacing: -0.02em;
  background: linear-gradient(90deg, rgba(53,210,255,0.95), rgba(247,192,69,0.95), rgba(255,79,216,0.95));
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.timebox__label{
  margin-top: 6px;
  font-size: 11px;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: 0.12em;
  font-family: var(--mono);
}
.countdown__meta{
  display:flex;
  align-items:center;
  gap:10px;
  margin-top: 12px;
  flex-wrap:wrap;
}
.muted{color: var(--muted)}
.tiny{font-size: 12px}
.badge{filter: drop-shadow(0 8px 16px rgba(0,0,0,0.35));}

.grid{
  display:grid;
  grid-template-columns: 1.2fr 0.8fr;
  gap: 14px;
  margin-top: 14px;
}

.panel{
  padding: 16px;
  border-radius: var(--radius2);
  border: 1px solid rgba(245,233,210,0.12);
  background: rgba(11,15,23,0.40);
}
.panel__title{
  margin:0 0 8px;
  font-size: 14px;
  font-family: var(--mono);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: rgba(245,233,210,0.86);
}
.panel__text{margin:0 0 12px; color: var(--muted); line-height:1.45}

.bullets{margin:0; padding-left: 18px; color: var(--text)}
.bullets li{margin: 8px 0; color: rgba(245,233,210,0.86)}
.bullets li::marker{color: rgba(53,210,255,0.75)}

.form{
  display:flex;
  gap:10px;
  align-items:center;
}
input[type="email"], input[type="datetime-local"]{
  width: 100%;
  padding: 12px 12px;
  border-radius: 14px;
  border: 1px solid rgba(245,233,210,0.16);
  background: rgba(18,24,38,0.55);
  color: var(--text);
  outline: none;
}
input::placeholder{color: rgba(245,233,210,0.45)}
input:focus{
  border-color: rgba(53,210,255,0.55);
  box-shadow: 0 0 0 5px rgba(53,210,255,0.12);
}

.btn{
  position:relative;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  padding: 12px 14px;
  border-radius: 14px;
  border: 1px solid rgba(245,233,210,0.14);
  background: linear-gradient(90deg, rgba(53,210,255,0.22), rgba(255,79,216,0.18), rgba(247,192,69,0.16));
  color: var(--cream);
  font-weight: 800;
  cursor:pointer;
  white-space:nowrap;
  transition: transform .15s ease, filter .15s ease, border-color .15s ease;
}
.btn:hover{transform: translateY(-1px); filter: brightness(1.08); border-color: rgba(53,210,255,0.35);}
.btn:active{transform: translateY(0px);}
.btn__spark{opacity:0.95}

.pill{
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding: 10px 12px;
  border-radius: 999px;
  border: 1px solid rgba(245,233,210,0.16);
  background: rgba(18,24,38,0.40);
  color: var(--cream);
  text-decoration:none;
  cursor:pointer;
  backdrop-filter: blur(10px);
}
.pill--ghost{background: rgba(11,15,23,0.25);}
.pill:hover{border-color: rgba(245,233,210,0.28)}
.pill__text{font-family: var(--mono); font-size: 12px}

.linklike{
  background: none;
  border: none;
  padding: 0;
  color: rgba(53,210,255,0.92);
  font-family: var(--mono);
  cursor:pointer;
  text-decoration: underline;
  text-underline-offset: 3px;
}
.linklike:hover{color: rgba(247,192,69,0.92)}
.linklike:focus{outline: 2px solid rgba(53,210,255,0.45); outline-offset: 4px; border-radius: 8px;}

.social{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  margin-top: 12px;
}
.social__link{
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding: 10px 12px;
  border-radius: 999px;
  border: 1px solid rgba(245,233,210,0.12);
  color: var(--cream);
  text-decoration:none;
  background: rgba(18,24,38,0.36);
  font-family: var(--mono);
  font-size: 12px;
}
.social__link:hover{border-color: rgba(53,210,255,0.35);}

.footer__left, .footer__right{display:flex; align-items:center; gap:10px; flex-wrap:wrap;}

/* ---------------- Toast ---------------- */
.toast{
  position: fixed;
  left: 50%;
  bottom: 22px;
  transform: translateX(-50%);
  z-index: 99;
  display:none;
}
.toast.is-open{display:block;}
.toast__card{
  display:flex;
  align-items:center;
  gap:12px;
  padding: 12px 14px;
  border-radius: 999px;
  border: 1px solid rgba(245,233,210,0.16);
  background: rgba(11,15,23,0.78);
  box-shadow: 0 18px 60px rgba(0,0,0,0.55);
  backdrop-filter: blur(12px);
}
.toast__icon{
  width: 28px; height: 28px;
  border-radius: 999px;
  display:grid;
  place-items:center;
  background: rgba(84,140,91,0.18);
  border: 1px solid rgba(84,140,91,0.35);
}
.toast__text{color: var(--cream); font-family: var(--mono); font-size: 12px;}
.toast__close{
  margin-left: 6px;
  background: transparent;
  border: none;
  color: var(--muted);
  cursor:pointer;
  font-size: 16px;
}

/* ---------------- Modal ---------------- */
.modal::backdrop{background: rgba(0,0,0,0.55); backdrop-filter: blur(3px);}
.modal{
  border: none;
  padding: 0;
  background: transparent;
  width: min(520px, calc(100% - 28px));
}
.modal__card{
  padding: 18px;
  border-radius: var(--radius);
  border: 1px solid rgba(245,233,210,0.16);
  background: rgba(11,15,23,0.88);
  box-shadow: var(--shadow);
}
.modal__title{margin: 0 0 6px; font-size: 18px}
.modal__text{margin: 0 0 14px; color: var(--muted)}
.modal__label{display:block; margin: 0 0 8px; font-family: var(--mono); font-size: 12px; color: rgba(245,233,210,0.82)}
.modal__actions{display:flex; justify-content:flex-end; gap:10px; margin-top: 14px}

/* ---------------- Responsive ---------------- */
@media (max-width: 860px){
  .countdown__grid{grid-template-columns: repeat(2,1fr);}
  .grid{grid-template-columns: 1fr; }
}
@media (max-width: 480px){
  .topbar{flex-direction:column; align-items:flex-start;}
  .form{flex-direction:column; align-items:stretch;}
  .btn{width:100%;}
}

/* Helpers */
.sr-only{
  position:absolute !important;
  width:1px; height:1px;
  padding:0; margin:-1px;
  overflow:hidden; clip:rect(0,0,0,0);
  white-space:nowrap; border:0;
}
