/* ============================================================
   CONLYT – Shared Design System v2
   Fonts: Unbounded (display) + Plus Jakarta Sans (body)
   ============================================================ */

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

:root {
  --black:   #080808;
  --dark:    #0f0f0f;
  --dark2:   #161616;
  --dark3:   #1e1e1e;
  --white:   #f5f5f0;
  --gray:    #777;
  --gray2:   #444;
  --border:  rgba(255,255,255,0.06);

  --gold:    #c8a96e;
  --blue:    #4f9cf9;
  --violet:  #a78bfa;
  --hq:      #f5f5f0;
  --accent:  #c8a96e;

  --font-display: 'Unbounded', sans-serif;
  --font-body:    'Plus Jakarta Sans', sans-serif;
}

/* RESET */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; -webkit-font-smoothing:antialiased; -webkit-text-size-adjust:100%; }
body { background:var(--black); color:var(--white); font-family:var(--font-body); overflow-x:hidden; cursor:none; }
a { text-decoration:none; color:inherit; }
button { cursor:none; }
img { max-width:100%; display:block; }

/* CURSOR (desktop only) */
.cursor      { width:8px; height:8px; background:var(--white); border-radius:50%; position:fixed; pointer-events:none; z-index:9999; transform:translate(-50%,-50%); mix-blend-mode:difference; transition:transform .1s; }
.cursor-ring { width:32px; height:32px; border:1px solid rgba(255,255,255,0.35); border-radius:50%; position:fixed; pointer-events:none; z-index:9998; transform:translate(-50%,-50%); mix-blend-mode:difference; transition:all .12s ease; }
body:has(a:hover) .cursor-ring,
body:has(button:hover) .cursor-ring { transform:translate(-50%,-50%) scale(1.6); border-color:var(--accent); }

/* NAV */
.nav {
  position:fixed; top:0; left:0; right:0; z-index:200;
  display:flex; align-items:center; justify-content:space-between;
  padding:1.4rem 5vw;
  transition:background .3s, border-color .3s;
}
.nav.scrolled {
  background:rgba(8,8,8,0.96);
  backdrop-filter:blur(20px);
  -webkit-backdrop-filter:blur(20px);
  border-bottom:1px solid var(--border);
}
.nav-logo { display:flex; align-items:center; gap:.5rem; }
.nav-logo svg { width:30px; height:30px; }
.nav-wordmark { font-family:var(--font-display); font-weight:900; font-size:1.1rem; letter-spacing:-.02em; color:var(--white); }
.nav-wordmark span { color:var(--accent); }
.nav-badge { font-family:var(--font-display); font-size:.5rem; font-weight:700; letter-spacing:.2em; text-transform:uppercase; border:1px solid; padding:.2rem .5rem; margin-left:.4rem; opacity:.8; }
.nav-links { display:flex; align-items:center; gap:2.5rem; list-style:none; }
.nav-links a { font-family:var(--font-display); font-size:.55rem; font-weight:600; letter-spacing:.15em; text-transform:uppercase; color:var(--gray); transition:color .2s; white-space:nowrap; }
.nav-links a:hover { color:var(--white); }
.nav-links .nav-cta { color:var(--black) !important; background:var(--white); padding:.55rem 1.3rem; transition:background .2s !important; }
.nav-links .nav-cta:hover { background:var(--accent) !important; }

/* HAMBURGER */
.hamburger { display:none; flex-direction:column; gap:5px; background:none; border:none; padding:8px; min-width:44px; min-height:44px; align-items:center; justify-content:center; }
.hamburger span { display:block; width:22px; height:1.5px; background:var(--white); transition:all .3s; }
.hamburger.open span:nth-child(1) { transform:rotate(45deg) translate(4.5px,4.5px); }
.hamburger.open span:nth-child(2) { opacity:0; }
.hamburger.open span:nth-child(3) { transform:rotate(-45deg) translate(4.5px,-4.5px); }

/* MOBILE MENU */
.mobile-menu {
  display:none; position:fixed; top:62px; inset-inline:0;
  background:rgba(8,8,8,.99); backdrop-filter:blur(20px); -webkit-backdrop-filter:blur(20px);
  border-bottom:1px solid var(--border); z-index:199;
  padding:1rem 6vw 2.5rem; flex-direction:column;
  max-height:calc(100svh - 62px); overflow-y:auto;
}
.mobile-menu.open { display:flex; }
.mobile-menu a {
  font-family:var(--font-display); font-weight:700; font-size:1.1rem;
  letter-spacing:-.01em; padding:1rem 0; border-bottom:1px solid var(--border);
  color:var(--gray); transition:color .2s;
  min-height:56px; display:flex; align-items:center;
}
.mobile-menu a:last-child { border-bottom:none; }
.mobile-menu a:hover, .mobile-menu a:active { color:var(--white); }

/* SECTION LABELS */
.label {
  font-family:var(--font-display); font-size:.55rem; font-weight:600;
  letter-spacing:.25em; text-transform:uppercase; color:var(--gray);
  display:flex; align-items:center; gap:.8rem; margin-bottom:1rem;
}
.label::before { content:''; width:24px; height:1px; background:var(--accent); flex-shrink:0; }
.section-title {
  font-family:var(--font-display); font-weight:900;
  font-size:clamp(1.6rem,3vw,2.4rem); letter-spacing:-.03em;
  line-height:1.05; margin-bottom:3rem;
}

/* BUTTONS */
.btn {
  display:inline-flex; align-items:center; justify-content:center;
  font-family:var(--font-display); font-weight:700; font-size:.6rem;
  letter-spacing:.15em; text-transform:uppercase;
  padding:.9rem 2rem; transition:all .2s; border:none;
  min-height:48px; /* touch target */
  -webkit-tap-highlight-color:transparent;
}
.btn-primary { background:var(--accent); color:var(--black); }
.btn-primary:hover { background:var(--white); }
.btn-outline { border:1px solid rgba(255,255,255,.15); color:var(--white); }
.btn-outline:hover { border-color:var(--accent); color:var(--accent); }
.btn-white { background:var(--white); color:var(--black); }
.btn-white:hover { background:var(--accent); }

/* FORMS */
.form-grid { display:grid; grid-template-columns:1fr 1fr; gap:1.2rem; }
.form-group { display:flex; flex-direction:column; gap:.4rem; }
.form-group.full { grid-column:1/-1; }
.form-group label {
  font-family:var(--font-display); font-size:.5rem; font-weight:700;
  letter-spacing:.2em; text-transform:uppercase; color:var(--gray);
}
.form-group input,
.form-group select,
.form-group textarea {
  background:rgba(255,255,255,.03);
  border:1px solid var(--border);
  color:var(--white);
  padding:.85rem 1rem;
  font-family:var(--font-body);
  font-size:16px; /* prevents iOS zoom */
  font-weight:300;
  outline:none;
  transition:border-color .2s, background .2s;
  width:100%;
  -webkit-appearance:none;
  border-radius:0;
  min-height:48px;
}
.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus { border-color:var(--accent); background:rgba(200,169,110,.03); }
.form-group select option { background:var(--dark); }
.form-group textarea { min-height:130px; resize:vertical; }
.form-msg {
  display:none; padding:.9rem 1.2rem; margin-top:1rem;
  font-family:var(--font-display); font-size:.55rem;
  letter-spacing:.1em; text-transform:uppercase; font-weight:700; text-align:center;
}
.form-msg.success { background:rgba(200,169,110,.07); border:1px solid rgba(200,169,110,.25); color:var(--gold); }
.form-msg.error   { background:rgba(239,68,68,.07);   border:1px solid rgba(239,68,68,.25);   color:#ef4444; }

/* REVEAL ANIMATIONS */
.reveal { opacity:0; transform:translateY(28px); transition:opacity .65s ease, transform .65s ease; }
.reveal.visible { opacity:1; transform:translateY(0); }
.reveal-delay-1 { transition-delay:.1s; }
.reveal-delay-2 { transition-delay:.2s; }
.reveal-delay-3 { transition-delay:.3s; }

/* FOOTER */
.footer { padding:4rem 5vw 2rem; border-top:1px solid var(--border); }
.footer-grid { display:grid; grid-template-columns:2fr 1fr 1fr 1fr; gap:3rem; max-width:1200px; margin:0 auto 3rem; }
.footer-brand p { font-size:.85rem; color:var(--gray); font-weight:300; line-height:1.8; margin-top:1rem; max-width:260px; }
.footer-col h4 { font-family:var(--font-display); font-weight:700; font-size:.5rem; letter-spacing:.25em; text-transform:uppercase; color:var(--white); margin-bottom:1.2rem; }
.footer-col ul { list-style:none; display:flex; flex-direction:column; gap:.6rem; }
.footer-col ul li a { font-size:.85rem; color:var(--gray); font-weight:300; transition:color .2s; min-height:36px; display:flex; align-items:center; }
.footer-col ul li a:hover { color:var(--accent); }
.footer-bottom {
  display:flex; justify-content:space-between; align-items:center;
  padding-top:2rem; border-top:1px solid var(--border);
  max-width:1200px; margin:0 auto; font-size:.75rem; color:var(--gray2);
}
.footer-bottom a { color:var(--gray2); transition:color .2s; }
.footer-bottom a:hover { color:var(--accent); }

/* COOKIE BANNER */
.cookie-banner {
  position:fixed; bottom:1.5rem; left:1.5rem; right:1.5rem; z-index:1000;
  background:var(--dark2); border:1px solid var(--border);
  padding:1.5rem 2rem;
  display:flex; align-items:center; justify-content:space-between; gap:2rem;
  transform:translateY(120%); opacity:0;
  transition:transform .5s ease, opacity .5s ease;
  max-width:900px; margin:0 auto;
}
.cookie-banner.show { transform:translateY(0); opacity:1; }
.cookie-text { font-size:.82rem; color:var(--gray); font-weight:300; line-height:1.6; }
.cookie-text a { color:var(--accent); text-decoration:underline; }
.cookie-text strong { color:var(--white); font-weight:500; }
.cookie-btns { display:flex; gap:.8rem; flex-shrink:0; }

/* GRID UTILITIES */
.container { max-width:1200px; margin:0 auto; padding:0 5vw; }
.section { padding:6rem 5vw; }
.section-lg { padding:8rem 5vw; }

/* ============================================================
   RESPONSIVE – Complete Mobile Optimization
   ============================================================ */

/* ── 1024px: Tablet landscape ── */
@media (max-width:1024px) {
  .footer-grid { grid-template-columns:1fr 1fr; gap:2rem; }
  .nav-links { gap:1.5rem; }
}

/* ── 900px: Tablet / large phone ── */
@media (max-width:900px) {
  /* Nav */
  .nav { padding:1rem 5vw; }
  .nav-links { display:none; }
  .hamburger { display:flex; cursor:pointer; }
  body { cursor:auto; }
  button { cursor:pointer; }
  a { cursor:pointer; }

  /* Hide cursor on touch */
  .cursor, .cursor-ring { display:none; }

  /* Section spacing */
  .section    { padding:4rem 5vw; }
  .section-lg { padding:5rem 5vw; }
  .section-title { margin-bottom:2rem; }

  /* Forms – single column */
  .form-grid { grid-template-columns:1fr; gap:1rem; }
  .form-group.full { grid-column:1; }

  /* Cookie */
  .cookie-banner { left:1rem; right:1rem; bottom:1rem; gap:1rem; }
}

/* ── 768px: Tablet portrait ── */
@media (max-width:768px) {
  .footer-grid { grid-template-columns:1fr 1fr; gap:1.5rem; }
  .section-title { font-size:clamp(1.5rem,5vw,2rem); }
}

/* ── 600px: Mobile ── */
@media (max-width:600px) {
  /* Nav */
  .nav { padding:.9rem 4vw; }
  .nav-wordmark { font-size:1rem; }
  .nav-badge { display:none; }
  .mobile-menu { top:58px; padding:.5rem 5vw 2rem; }
  .mobile-menu a { font-size:1rem; min-height:52px; }

  /* Footer */
  .footer { padding:2.5rem 4vw 1.5rem; }
  .footer-grid { grid-template-columns:1fr 1fr; gap:1.5rem; }
  .footer-brand { grid-column:1/-1; }
  .footer-brand p { max-width:100%; }
  .footer-bottom { flex-direction:column; gap:.6rem; text-align:center; font-size:.7rem; }
  .footer-bottom div { display:flex; flex-wrap:wrap; justify-content:center; gap:1rem; }

  /* Cookie */
  .cookie-banner { flex-direction:column; align-items:stretch; left:.5rem; right:.5rem; bottom:.5rem; padding:1.2rem; gap:1rem; }
  .cookie-btns { width:100%; }
  .cookie-btns .btn { flex:1; text-align:center; }

  /* Section */
  .section    { padding:3rem 4vw; }
  .section-lg { padding:3.5rem 4vw; }
  .section-title { font-size:clamp(1.3rem,6vw,1.8rem); margin-bottom:1.5rem; }
  .label { font-size:.48rem; }

  /* Buttons */
  .btn { font-size:.55rem; padding:.85rem 1.5rem; width:100%; justify-content:center; }

  /* Forms */
  .form-group input,
  .form-group select,
  .form-group textarea { padding:.9rem; }
}

/* ── 400px: Small phones ── */
@media (max-width:400px) {
  .nav { padding:.8rem 4vw; }
  .nav-wordmark { font-size:.9rem; }
  .section    { padding:2.5rem 4vw; }
  .section-lg { padding:3rem 4vw; }
  .section-title { font-size:clamp(1.2rem,7vw,1.5rem); }
  .footer-grid { grid-template-columns:1fr; }
  .cookie-banner { padding:1rem; }
  .cookie-text { font-size:.78rem; }
}
