/* ═══════════════════════════════════════
   THECSR Labs — Main Stylesheet
   Neo-Mirai · Navy + Gold Theme
═══════════════════════════════════════ */

:root {
  --bg:     #111827;
  --bg2:    #1a2335;
  --card:   #1f2d42;
  --gold:   #c47818;
  --gold2:  #e09d38;
  --gdim:   rgba(196,120,24,.1);
  --gglow:  rgba(196,120,24,.24);
  --red:    #a82a0e;
  --rdim:   rgba(168,42,14,.1);
  --cream:  #ede8d8;
  --warm:   #f5f0e6;
  --muted:  #7a90a8;
  --dim:    #3a4a5e;
  --border: rgba(196,120,24,.15);
  --borderh:rgba(196,120,24,.45);
  --fd: 'Cormorant Garamond', Georgia, serif;
  --fu: 'Josefin Sans', system-ui, sans-serif;
  --fb: 'Lora', Georgia, serif;
  --fm: 'IBM Plex Mono', monospace;
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html  { scroll-behavior: smooth; }
body  { font-family: var(--fb); background: var(--bg); color: var(--cream); overflow-x: hidden; line-height: 1.7; }

body::before {
  content: '';
  position: fixed; inset: 0; z-index: 0; pointer-events: none;
  background-image:
    linear-gradient(rgba(196,120,24,.018) 1px, transparent 1px),
    linear-gradient(90deg, rgba(196,120,24,.018) 1px, transparent 1px);
  background-size: 80px 80px;
}

section { position: relative; z-index: 1; padding: 100px 8%; }
.max    { max-width: 1100px; margin: 0 auto; }

/* ── NAVBAR ── */
nav {
  position: fixed; top: 0; left: 0; right: 0; z-index: 1000;
  height: 64px; padding: 0 8%;
  display: flex; align-items: center; justify-content: space-between;
  background: rgba(17,24,39,.97); backdrop-filter: blur(24px);
  border-bottom: 1px solid var(--border);
}
.nav-logo { display: flex; align-items: center; gap: 12px; text-decoration: none; }

/* Real logo image - gold transparent PNG */
.logo-img {
  width: 38px; height: 38px; object-fit: contain;
  transition: opacity .3s, transform .3s;
}
.nav-logo:hover .logo-img { opacity: .8; transform: rotate(-5deg) scale(1.05); }
.ltxt  { display: flex; flex-direction: column; }
.ltxt .la { font-family: var(--fd); font-weight: 700; font-size: 1rem; color: var(--gold); letter-spacing: 3px; line-height: 1; }
.ltxt .lb { font-family: var(--fu); font-weight: 300; font-size: .5rem; color: var(--muted); letter-spacing: 5px; text-transform: uppercase; line-height: 1; margin-top: 2px; }

.nav-links { display: flex; gap: 2.4rem; list-style: none; }
.nav-links a { font-family: var(--fu); font-weight: 400; font-size: .7rem; color: var(--muted); text-decoration: none; letter-spacing: 2px; text-transform: uppercase; transition: color .3s; }
.nav-links a:hover { color: var(--gold); }
.nav-cta { padding: 6px 18px !important; border: 1px solid var(--borderh) !important; color: var(--gold) !important; }
.nav-cta:hover { background: var(--gdim) !important; }

.hbg { display: none; flex-direction: column; gap: 5px; cursor: pointer; }
.hbg span { width: 22px; height: 1px; background: var(--gold); }
.mob { display: none; position: fixed; top: 64px; left: 0; right: 0; z-index: 999; background: rgba(17,24,39,.98); backdrop-filter: blur(24px); border-bottom: 1px solid var(--border); padding: 24px 8%; flex-direction: column; gap: 18px; }
.mob.open { display: flex; }
.mob a { font-family: var(--fu); font-size: .8rem; color: var(--cream); text-decoration: none; letter-spacing: 2px; text-transform: uppercase; padding-bottom: 14px; border-bottom: 1px solid var(--border); }

/* ── HERO ── */
#hero { min-height: 100vh; display: flex; align-items: center; padding: 120px 8% 80px; overflow: hidden; }

.sun { position: absolute; right: 6%; top: 50%; transform: translateY(-50%); width: min(500px,44vw); height: min(500px,44vw); border-radius: 50%; pointer-events: none; z-index: 0; }
.sr  { position: absolute; border-radius: 50%; border: 1px solid var(--border); animation: sR 30s linear infinite; }
.sr1 { inset: 0; } .sr2 { inset: 10%; animation-duration: 22s; animation-direction: reverse; } .sr3 { inset: 22%; border-color: rgba(196,120,24,.22); }
.sc  { position: absolute; inset: 32%; border-radius: 50%; background: radial-gradient(circle at 40% 40%, rgba(196,120,24,.28), rgba(168,42,14,.1), transparent 70%); animation: sP 4s ease-in-out infinite alternate; }
@keyframes sR { to { transform: rotate(360deg); } }
@keyframes sP { to { opacity: .55; transform: scale(1.06); } }
.vstamp { position: absolute; top: 90px; right: 8%; font-family: var(--fm); font-size: .58rem; color: var(--muted); letter-spacing: 2px; writing-mode: vertical-rl; opacity: .45; z-index: 1; }

.hi   { position: relative; z-index: 1; max-width: 680px; }
.eyebrow { display: flex; align-items: center; gap: 14px; font-family: var(--fm); font-size: .62rem; color: var(--muted); letter-spacing: 3px; text-transform: uppercase; margin-bottom: 26px; animation: fU .8s ease both; }
.edot  { width: 6px; height: 6px; border-radius: 50%; background: var(--gold); animation: dP 2s infinite; }
.eline { flex: 1; max-width: 40px; height: 1px; background: var(--gold); opacity: .5; }
@keyframes dP { 50% { opacity: .3; transform: scale(.7); } }

h1.hn { font-family: var(--fd); font-size: clamp(2.8rem, 6.2vw, 5.2rem); font-weight: 700; line-height: .95; letter-spacing: -1px; margin-bottom: 18px; animation: fU .8s .15s ease both; }
h1.hn .n1 { display: block; color: var(--warm); font-style: italic; }
h1.hn .n2 { display: block; color: var(--gold); }
h1.hn .n3 { display: block; color: transparent; -webkit-text-stroke: 1px rgba(196,120,24,.26); font-size: .42em; letter-spacing: 8px; font-style: normal; }

.roles  { display: flex; align-items: center; gap: 14px; margin-bottom: 20px; animation: fU .8s .28s ease both; }
.rline  { height: 1px; background: linear-gradient(90deg, var(--gold), transparent); width: 80px; opacity: .5; }
.rtags  { display: flex; flex-wrap: wrap; gap: 7px; }
.rtag   { font-family: var(--fu); font-size: .66rem; font-weight: 600; color: var(--gold); letter-spacing: 2px; text-transform: uppercase; padding: 4px 12px; border: 1px solid rgba(196,120,24,.28); border-radius: 1px; }

.hdesc  { font-family: var(--fb); font-size: 1rem; color: var(--muted); max-width: 520px; line-height: 2; margin-bottom: 40px; animation: fU .8s .42s ease both; }
.hdesc strong { color: var(--cream); font-weight: 500; }
.hdesc em     { color: var(--gold2); font-style: normal; }

.hbtns { display: flex; flex-wrap: wrap; gap: 13px; animation: fU .8s .56s ease both; }
.btn   { display: inline-flex; align-items: center; gap: 8px; cursor: pointer; font-family: var(--fu); font-size: .67rem; font-weight: 700; letter-spacing: 2.5px; text-transform: uppercase; text-decoration: none; padding: 13px 28px; border-radius: 1px; border: none; transition: all .3s; }
.btng  { background: var(--gold); color: var(--bg); }
.btng:hover { background: var(--gold2); transform: translateY(-2px); box-shadow: 0 8px 28px var(--gglow); }
.btno  { background: transparent; color: var(--gold); border: 1px solid rgba(196,120,24,.45); }
.btno:hover { background: var(--gdim); transform: translateY(-2px); }
.btnw  { background: rgba(37,211,102,.1); color: #5de08c; border: 1px solid rgba(37,211,102,.25); }
.btnw:hover { background: rgba(37,211,102,.18); transform: translateY(-2px); }

.hstats { display: flex; flex-wrap: wrap; gap: 48px; margin-top: 56px; padding-top: 48px; border-top: 1px solid var(--border); animation: fU .8s .7s ease both; }
.stat .n { font-family: var(--fd); font-size: 2.8rem; font-weight: 700; color: var(--gold); display: block; line-height: 1; }
.stat .l { font-family: var(--fu); font-size: .6rem; color: var(--muted); letter-spacing: 2px; text-transform: uppercase; margin-top: 4px; }

/* ── SECTION HEADERS ── */
.sh  { text-align: center; margin-bottom: 70px; }
.sn  { font-family: var(--fm); font-size: .6rem; color: var(--red); letter-spacing: 4px; text-transform: uppercase; margin-bottom: 12px; display: block; }
.st  { font-family: var(--fd); font-size: clamp(1.8rem, 3.5vw, 2.8rem); font-weight: 700; color: var(--warm); letter-spacing: -.5px; line-height: 1.1; margin-bottom: 20px; }
.st em { font-style: italic; color: var(--gold); }
.sl  { display: flex; align-items: center; gap: 16px; justify-content: center; }
.sl::before, .sl::after { content: ''; flex: 1; max-width: 60px; height: 1px; background: linear-gradient(90deg, transparent, var(--gold)); }
.sl::after { background: linear-gradient(270deg, transparent, var(--gold)); }
.sl span   { font-family: var(--fm); font-size: .55rem; color: var(--gold); letter-spacing: 3px; text-transform: uppercase; }

/* ── ABOUT ── */
#about { background: var(--bg2); }
.ag    { display: grid; grid-template-columns: 1.1fr 1fr; gap: 72px; align-items: center; }
.at p  { font-family: var(--fb); font-size: .97rem; color: var(--muted); line-height: 2; margin-bottom: 20px; }
.at p strong { color: var(--gold); font-weight: 500; }
.at p em     { color: var(--cream); font-style: italic; }
.abtns { display: flex; gap: 12px; flex-wrap: wrap; margin-top: 28px; }
.abtn  { font-family: var(--fu); font-size: .63rem; font-weight: 600; letter-spacing: 2px; text-transform: uppercase; text-decoration: none; padding: 10px 18px; color: var(--gold); border: 1px solid rgba(196,120,24,.35); border-radius: 1px; transition: all .3s; }
.abtn:hover { background: var(--gdim); }
.acs   { display: flex; flex-direction: column; gap: 1px; }
.ac    { padding: 19px 22px; background: var(--card); border-left: 2px solid var(--gold); transition: all .3s; cursor: default; }
.ac:hover { border-left-color: var(--red); background: #1d2f47; transform: translateX(5px); }
.ac h4 { font-family: var(--fu); font-size: .63rem; font-weight: 700; color: var(--gold); letter-spacing: 2px; text-transform: uppercase; margin-bottom: 5px; }
.ac p  { font-family: var(--fb); font-size: .8rem; color: var(--muted); margin: 0; }

/* ── TIMELINE ── */
#timeline { background: var(--bg); }
.tlw  { max-width: 760px; margin: 0 auto; }
.tli  { margin-bottom: 34px; display: grid; grid-template-columns: 110px 1fr; gap: 28px; align-items: start; position: relative; }
.tli::before { content: ''; position: absolute; left: 97px; top: 0; bottom: -34px; width: 1px; background: linear-gradient(to bottom, var(--gold), rgba(196,120,24,.04)); }
.tly  { font-family: var(--fm); font-size: .6rem; color: var(--gold); letter-spacing: 2px; text-align: right; padding-top: 4px; }
.tlb  { padding-left: 22px; position: relative; }
.tlb::before { content: ''; position: absolute; left: -4px; top: 8px; width: 8px; height: 8px; border-radius: 50%; background: var(--gold); border: 1px solid var(--bg); box-shadow: 0 0 10px var(--gglow); }
.tlb h4 { font-family: var(--fd); font-size: 1.04rem; font-weight: 600; color: var(--cream); margin-bottom: 6px; }
.tlb p  { font-family: var(--fb); font-size: .82rem; color: var(--muted); line-height: 1.85; }

/* ── SKILLS ── */
#skills { background: var(--bg2); }
.sg    { display: grid; grid-template-columns: repeat(auto-fit, minmax(270px, 1fr)); gap: 1px; border: 1px solid var(--border); }
.sk    { background: var(--card); padding: 26px; transition: background .3s; }
.sk:hover { background: #243352; }
.scat  { font-family: var(--fu); font-size: .58rem; font-weight: 700; color: var(--red); letter-spacing: 3px; text-transform: uppercase; margin-bottom: 14px; display: flex; align-items: center; gap: 10px; }
.scat::after { content: ''; flex: 1; height: 1px; background: var(--border); }
.stgs  { display: flex; flex-wrap: wrap; gap: 7px; }
.stag  { font-family: var(--fu); font-size: .67rem; padding: 5px 13px; border: 1px solid var(--border); color: var(--cream); border-radius: 1px; transition: all .2s; cursor: default; letter-spacing: .5px; }
.stag:hover { border-color: var(--gold); color: var(--gold); background: var(--gdim); }
.stag.r { border-color: rgba(168,42,14,.2); }
.stag.r:hover { border-color: var(--red); color: var(--red); background: var(--rdim); }
.stag.g { border-color: rgba(93,224,140,.15); color: #7ad8a0; }

/* ── SERVICES ── */
#services { background: var(--bg); }
.srvg  { display: grid; grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)); gap: 24px; }
.srvc  { background: var(--card); border: 1px solid var(--border); padding: 30px 26px; position: relative; overflow: hidden; transition: all .35s; }
.srvc::after { content: ''; position: absolute; bottom: 0; left: 0; right: 0; height: 2px; background: linear-gradient(90deg, var(--gold), var(--red)); transform: scaleX(0); transform-origin: left; transition: transform .35s; }
.srvc:hover::after { transform: scaleX(1); }
.srvc:hover { transform: translateY(-5px); background: #1d2f47; border-color: rgba(196,120,24,.28); }
.srvc .sn2 { font-family: var(--fm); font-size: .58rem; color: var(--dim); letter-spacing: 2px; margin-bottom: 18px; display: block; }
.srvc h3   { font-family: var(--fd); font-size: 1.15rem; font-weight: 600; color: var(--cream); margin-bottom: 11px; }
.srvc p    { font-family: var(--fb); font-size: .82rem; color: var(--muted); line-height: 1.9; margin-bottom: 14px; }
.stg2      { display: flex; flex-wrap: wrap; gap: 6px; }
.stg2 span { font-family: var(--fm); font-size: .6rem; padding: 3px 9px; background: rgba(196,120,24,.06); border: 1px solid rgba(196,120,24,.15); color: var(--gold); border-radius: 1px; }

/* ── PRODUCTS ── */
#products { background: var(--bg2); }
.pg    { display: grid; grid-template-columns: repeat(auto-fit, minmax(310px, 1fr)); gap: 26px; }
.pc    { background: var(--card); border: 1px solid var(--border); position: relative; overflow: hidden; transition: all .35s; display: flex; flex-direction: column; }
.pc:hover { transform: translateY(-6px); border-color: var(--gold); box-shadow: 0 20px 50px rgba(0,0,0,.5), 0 0 28px var(--gglow); }
.pbdg  { position: absolute; top: 14px; right: 14px; font-family: var(--fu); font-size: .54rem; font-weight: 700; padding: 4px 9px; letter-spacing: 1.5px; border-radius: 1px; }
.pbn   { background: var(--gold); color: var(--bg); }
.pbs   { background: var(--red); color: var(--warm); }
.pba   { background: rgba(93,224,140,.14); border: 1px solid rgba(93,224,140,.28); color: #5de08c; }
.ph    { padding: 26px 24px 18px; border-bottom: 1px solid var(--border); }
.pico  { font-size: 1.7rem; margin-bottom: 10px; }
.ph h3 { font-family: var(--fd); font-size: 1.05rem; font-weight: 600; color: var(--cream); margin-bottom: 7px; }
.ph p  { font-family: var(--fb); font-size: .79rem; color: var(--muted); line-height: 1.8; }
.pb2   { padding: 18px 24px 22px; flex: 1; display: flex; flex-direction: column; }
.pf    { list-style: none; margin-bottom: 18px; flex: 1; }
.pf li { display: flex; gap: 9px; font-family: var(--fb); font-size: .79rem; color: var(--muted); padding: 4px 0; border-bottom: 1px solid rgba(196,120,24,.05); }
.pf li::before { content: '—'; color: var(--gold); flex-shrink: 0; opacity: .7; }
.pbtns { display: flex; gap: 8px; margin-top: 16px; }
.pbtns a { flex: 1; padding: 9px 12px; text-align: center; text-decoration: none; font-family: var(--fu); font-size: .58rem; font-weight: 700; letter-spacing: 1.5px; text-transform: uppercase; transition: all .3s; border-radius: 1px; }
.pd    { background: transparent; color: var(--gold); border: 1px solid rgba(196,120,24,.38); }
.pd:hover { background: var(--gdim); }
.pbu   { background: var(--gold); color: var(--bg); border: 1px solid var(--gold); }
.pbu:hover { background: var(--gold2); box-shadow: 0 0 20px var(--gglow); }

/* ── PORTFOLIO ── */
#portfolio { background: var(--bg); }
.pog  { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: 1px; border: 1px solid var(--border); }
.poc  { background: var(--card); padding: 24px; transition: background .3s; }
.poc:hover { background: #243352; }
.pom  { display: flex; align-items: center; justify-content: space-between; margin-bottom: 10px; }
.poy  { font-family: var(--fm); font-size: .58rem; color: var(--muted); }
.pot  { font-family: var(--fu); font-size: .58rem; font-weight: 700; padding: 3px 8px; background: var(--rdim); border: 1px solid rgba(168,42,14,.2); color: var(--red); letter-spacing: 1px; text-transform: uppercase; }
.poc h3 { font-family: var(--fd); font-size: 1rem; font-weight: 600; color: var(--cream); margin-bottom: 7px; }
.poc p  { font-family: var(--fb); font-size: .79rem; color: var(--muted); margin-bottom: 13px; line-height: 1.8; }
.pol    { font-family: var(--fm); font-size: .62rem; color: var(--gold); text-decoration: none; letter-spacing: .8px; transition: color .2s; }
.pol:hover { color: var(--gold2); }

/* ── CONTACT ── */
#contact { background: var(--bg2); }
.cg   { display: grid; grid-template-columns: 1fr 1.6fr; gap: 64px; }
.ci h3 { font-family: var(--fd); font-size: 1.5rem; font-weight: 600; color: var(--cream); margin-bottom: 28px; line-height: 1.3; font-style: italic; }
.citm  { display: flex; align-items: flex-start; gap: 14px; margin-bottom: 20px; }
.cico  { width: 38px; height: 38px; display: flex; align-items: center; justify-content: center; background: var(--gdim); border: 1px solid var(--border); font-size: .95rem; flex-shrink: 0; }
.cdet span { font-family: var(--fu); font-size: .58rem; color: var(--muted); text-transform: uppercase; letter-spacing: 2px; margin-bottom: 2px; display: block; }
.cdet a, .cdet p { font-family: var(--fb); color: var(--cream); font-size: .9rem; text-decoration: none; }
.cdet a:hover { color: var(--gold); }
.socs  { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 24px; }
.sb    { font-family: var(--fu); font-size: .6rem; font-weight: 600; padding: 7px 14px; background: var(--gdim); border: 1px solid var(--border); color: var(--gold); text-decoration: none; letter-spacing: 1.5px; text-transform: uppercase; transition: all .3s; border-radius: 1px; }
.sb:hover { background: var(--gold); color: var(--bg); }
.cf    { display: flex; flex-direction: column; gap: 14px; }
.fr    { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.fg    { display: flex; flex-direction: column; gap: 5px; }
.fg label { font-family: var(--fu); font-size: .58rem; color: var(--muted); text-transform: uppercase; letter-spacing: 2px; }
.fg input, .fg textarea, .fg select { padding: 11px 14px; background: var(--card); border: 1px solid var(--border); color: var(--cream); font-family: var(--fb); font-size: .88rem; outline: none; transition: all .25s; }
.fg input:focus, .fg textarea:focus, .fg select:focus { border-color: var(--gold); background: #1d2f47; }
.fg select option { background: var(--card); }
.fg textarea { resize: vertical; min-height: 100px; }
#fs2   { display: none; padding: 11px 14px; font-family: var(--fu); font-size: .72rem; margin-top: 4px; letter-spacing: 1px; }

/* ── FOOTER ── */
footer { background: var(--bg); border-top: 1px solid var(--border); padding: 44px 8%; position: relative; z-index: 1; }
.fdiv  { height: 1px; background: linear-gradient(90deg, transparent, var(--gold), transparent); margin-bottom: 36px; opacity: .3; }
.fi    { display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 22px; }
.flogo .fl1 { font-family: var(--fd); font-weight: 700; font-size: 1.05rem; color: var(--gold); letter-spacing: 2px; }
.flogo .fl2 { font-family: var(--fu); font-size: .5rem; color: var(--muted); letter-spacing: 5px; text-transform: uppercase; margin-top: 2px; }
.fln   { display: flex; gap: 22px; }
.fln a { font-family: var(--fu); font-size: .66rem; color: var(--muted); text-decoration: none; letter-spacing: 1.5px; text-transform: uppercase; transition: color .2s; }
.fln a:hover { color: var(--gold); }
.fcp   { font-family: var(--fm); font-size: .62rem; color: var(--dim); }

/* ── FLOATS ── */
.waf   { position: fixed; bottom: 86px; right: 22px; width: 48px; height: 48px; border-radius: 50%; background: #25d366; display: flex; align-items: center; justify-content: center; font-size: 1.3rem; z-index: 900; text-decoration: none; box-shadow: 0 4px 20px rgba(37,211,102,.4); transition: all .3s; animation: waP 2.5s ease-in-out infinite; }
.waf:hover { transform: scale(1.1); }
@keyframes waP { 50% { box-shadow: 0 4px 30px rgba(37,211,102,.65), 0 0 0 8px rgba(37,211,102,.1); } }
.cfab  { position: fixed; bottom: 22px; right: 22px; width: 48px; height: 48px; background: var(--gold); border-radius: 50%; border: none; display: flex; align-items: center; justify-content: center; font-size: 1.2rem; z-index: 900; cursor: pointer; color: var(--bg); box-shadow: 0 4px 20px var(--gglow); transition: all .3s; }
.cfab:hover { transform: scale(1.1); background: var(--gold2); }

/* ── AI CHAT ── */
.cw    { position: fixed; bottom: 84px; right: 22px; width: 350px; height: 480px; background: var(--bg2); border: 1px solid var(--border); z-index: 899; display: none; flex-direction: column; overflow: hidden; box-shadow: 0 20px 60px rgba(0,0,0,.8), 0 0 36px var(--gglow); }
.cw.open { display: flex; animation: cUp .3s ease; }
@keyframes cUp { from { opacity: 0; transform: translateY(20px); } }
.chwh  { padding: 14px 18px; background: var(--card); border-bottom: 1px solid var(--border); display: flex; align-items: center; gap: 11px; }
.chav  { width: 33px; height: 33px; border-radius: 50%; background: linear-gradient(135deg, var(--gold), var(--red)); display: flex; align-items: center; justify-content: center; font-size: .95rem; flex-shrink: 0; }
.chinf h4 { font-family: var(--fu); font-size: .76rem; font-weight: 700; color: var(--cream); letter-spacing: 1px; }
.chinf p  { font-family: var(--fm); font-size: .6rem; color: #5de08c; }
.chcl  { margin-left: auto; background: none; border: none; color: var(--muted); cursor: pointer; font-size: .88rem; transition: color .2s; }
.chcl:hover { color: var(--cream); }
.cms   { flex: 1; overflow-y: auto; padding: 13px; display: flex; flex-direction: column; gap: 9px; }
.cms::-webkit-scrollbar { width: 3px; }
.cms::-webkit-scrollbar-thumb { background: var(--border); }
.cm    { max-width: 86%; padding: 10px 13px; font-family: var(--fb); font-size: .79rem; line-height: 1.65; }
.cm.bot { background: var(--card); border: 1px solid var(--border); color: var(--cream); align-self: flex-start; }
.cm.usr { background: var(--gold); color: var(--bg); align-self: flex-end; font-weight: 500; }
.cm.typ { display: flex; gap: 4px; align-items: center; padding: 12px 15px; }
.td    { width: 5px; height: 5px; border-radius: 50%; background: var(--muted); animation: tdA 1.2s ease-in-out infinite; }
.td:nth-child(2) { animation-delay: .2s; } .td:nth-child(3) { animation-delay: .4s; }
@keyframes tdA { 50% { transform: translateY(-5px); opacity: 1; } 0%, 100% { opacity: .3; } }
.cia   { padding: 11px 13px; border-top: 1px solid var(--border); display: flex; gap: 7px; }
.cin   { flex: 1; padding: 9px 12px; background: var(--card); border: 1px solid var(--border); color: var(--cream); font-family: var(--fb); font-size: .79rem; outline: none; transition: border-color .2s; }
.cin:focus { border-color: var(--gold); }
.csnd  { width: 34px; height: 34px; background: var(--gold); border: none; color: var(--bg); cursor: pointer; font-size: .85rem; transition: all .2s; flex-shrink: 0; display: flex; align-items: center; justify-content: center; }
.csnd:hover { background: var(--gold2); }
.csnd:disabled { opacity: .4; cursor: not-allowed; }

/* ── ANIMATIONS ── */
@keyframes fU { from { opacity: 0; transform: translateY(22px); } to { opacity: 1; transform: translateY(0); } }
.obs   { opacity: 0; transform: translateY(28px); transition: opacity .7s ease, transform .7s ease; }
.obs.vis { opacity: 1; transform: translateY(0); }

/* ── RESPONSIVE ── */
@media (max-width: 960px) {
  .ag { grid-template-columns: 1fr; gap: 40px; }
  .cg { grid-template-columns: 1fr; gap: 40px; }
  .sun { display: none; }
}
@media (max-width: 768px) {
  section { padding: 70px 5%; }
  .nav-links { display: none !important; }
  .hbg { display: flex; }
  .hstats { gap: 22px; }
  .fr { grid-template-columns: 1fr; }
  .cw { width: calc(100vw - 28px); right: 14px; }
  .fi { flex-direction: column; text-align: center; }
  .fln { justify-content: center; flex-wrap: wrap; }
  .sg  { grid-template-columns: 1fr; }
  .pog { grid-template-columns: 1fr; }
}
