/* ═══════════════════════════════════════
   TOKENS — matched to elliot_weiss_logo.svg
   Gold #c9a96e · Dark gold #8a6e3e · Cream #f5f0e8 · BG #0d0d0d
   ═══════════════════════════════════════ */
:root {
  --bg:        #0d0d0d;
  --bg-card:   rgba(201,169,110,0.04);
  --bg-glass:  rgba(201,169,110,0.06);
  --border:    rgba(201,169,110,0.12);
  --text:      #d4cfc6;
  --text-dim:  #8a8478;
  --white:     #f5f0e8;
  --gold:      #c9a96e;
  --gold-dark: #8a6e3e;
  --gold-light:#e2d1a8;
  --grad:      linear-gradient(135deg, #c9a96e, #e2d1a8, #8a6e3e);
  --grad-warm: linear-gradient(135deg, #c9a96e, #a3884e);
  --radius:    16px;
  --radius-sm: 10px;
  --font:      'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  --font-serif:'Cormorant Garamond', Georgia, serif;
  --max-w:     1140px;
  --nav-h:     72px;
}

/* ═══════════════════════════════════════
   RESET
   ═══════════════════════════════════════ */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior: smooth; scroll-padding-top: var(--nav-h); }
body {
  font-family: var(--font);
  background: var(--bg);
  color: var(--text);
  line-height: 1.65;
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
}
a { color: inherit; text-decoration: none; }
img { max-width: 100%; display: block; }
button { font-family: inherit; }

/* ═══════════════════════════════════════
   LAYOUT
   ═══════════════════════════════════════ */
.container    { max-width: var(--max-w); margin: 0 auto; padding: 0 1.5rem; }
.container-sm { max-width: 720px;       margin: 0 auto; padding: 0 1.5rem; }
section { padding: 7rem 0; }

/* ═══════════════════════════════════════
   GLASS HELPER
   ═══════════════════════════════════════ */
.glass-card {
  background: var(--bg-glass);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
}

/* ═══════════════════════════════════════
   NAVBAR
   ═══════════════════════════════════════ */
#navbar {
  position: fixed; inset: 0 0 auto 0;
  height: var(--nav-h);
  z-index: 200;
  transition: background .35s, border-color .35s, backdrop-filter .35s;
  border-bottom: 1px solid transparent;
}
#navbar.scrolled {
  background: rgba(13,13,13,0.82);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  border-bottom-color: var(--border);
}
.nav-inner {
  max-width: var(--max-w); margin:0 auto; padding:0 1.5rem;
  display:flex; align-items:center; justify-content:space-between;
  height:100%;
}
.logo {
  display:flex; align-items:center;
}
.nav-logo-img {
  height: 67px;
  width: auto;
}
.nav-links { display:flex; gap:2.25rem; }
.nav-links a {
  font-size: .9rem; font-weight: 500; color: var(--text-dim);
  transition: color .2s;
  letter-spacing: 0.5px;
}
.nav-links a:hover { color: var(--gold); }
.nav-linkedin {
  display:inline-flex; align-items:center; gap:.3rem;
  padding:0; border:none; background:none;
  font-size:.9rem;
}
.nav-linkedin i { font-size:.85rem; }

/* hamburger */
.hamburger {
  display:none; flex-direction:column; gap:5px;
  background:none; border:none; cursor:pointer; padding:4px;
}
.hamburger span { display:block; width:22px; height:2px; background:var(--gold); border-radius:2px; transition:.3s; }
.hamburger.active span:nth-child(1){ transform:rotate(45deg) translate(5px,5px); }
.hamburger.active span:nth-child(2){ opacity:0; }
.hamburger.active span:nth-child(3){ transform:rotate(-45deg) translate(5px,-5px); }

@media(max-width:640px){
  .hamburger { display:flex; }
  .nav-links {
    position:absolute; top:var(--nav-h); left:0; right:0;
    flex-direction:column; gap:0; display:none;
    background: rgba(13,13,13,.96); backdrop-filter:blur(14px);
    border-bottom:1px solid var(--border);
  }
  .nav-links.open { display:flex; }
  .nav-links a { padding:1rem 1.5rem; border-top:1px solid var(--border); }
}

/* ═══════════════════════════════════════
   BUTTONS
   ═══════════════════════════════════════ */
.btn {
  display:inline-flex; align-items:center; justify-content:center; gap:.5rem;
  padding:.8rem 1.75rem; border-radius:var(--radius-sm);
  font-size:.9rem; font-weight:600; border:none; cursor:pointer;
  transition: transform .2s, box-shadow .3s;
  position: relative;
}
.btn:hover { transform:translateY(-2px); }

.btn-glow {
  background: var(--grad-warm); color: #0d0d0d;
  box-shadow: 0 0 20px rgba(201,169,110,.2);
}
.btn-glow:hover { box-shadow: 0 0 32px rgba(201,169,110,.4); }

.btn-glass {
  background: var(--bg-glass); color: var(--gold-light);
  border: 1px solid var(--border);
  backdrop-filter: blur(8px);
}
.btn-glass:hover { border-color: var(--gold); color:var(--white); }

.btn-full { width:100%; }

/* ═══════════════════════════════════════
   HERO
   ═══════════════════════════════════════ */
#hero {
  min-height: 100vh; display:flex; align-items:center; justify-content:center;
  text-align:center; position:relative; overflow:hidden;
  padding: calc(var(--nav-h) + 2rem) 1.5rem 4rem;
}
.hero-bg { position:absolute; inset:0; pointer-events:none; }
.orb {
  position:absolute; border-radius:50%; filter:blur(100px); opacity:.25;
  animation: float 12s ease-in-out infinite alternate;
}
.orb-1 { width:500px; height:500px; background:#c9a96e; top:-15%; left:-10%; }
.orb-2 { width:400px; height:400px; background:#8a6e3e; bottom:-10%; right:-5%; animation-delay:4s; }
.orb-3 { width:300px; height:300px; background:#e2d1a8; top:40%; left:55%; animation-delay:8s; opacity:.15; }

@keyframes float {
  to { transform: translate(40px, 30px) scale(1.08); }
}

.hero-content { position:relative; z-index:1; max-width:700px; }

.hero-headshot {
  width: 168px;
  height: 168px;
  border-radius: 50%;
  object-fit: cover;
  object-position: center 15%;
  margin: 0 auto 2rem;
  border: 3px solid var(--gold);
  box-shadow: 0 0 30px rgba(201,169,110,.2), 0 0 60px rgba(201,169,110,.08);
}

.hero-badge {
  display:inline-block; padding:.4rem 1.1rem; border-radius:50px;
  font-size:.75rem; font-weight:600; letter-spacing:2px; text-transform:uppercase;
  background: var(--bg-glass); border:1px solid var(--border); color:var(--gold);
  margin-bottom:1.5rem;
}
#hero h1 {
  font-family: var(--font-serif);
  font-size: clamp(2.8rem, 6.5vw, 4.2rem);
  font-weight:600; line-height:1.15; letter-spacing:1px;
  color: var(--white); margin-bottom:1.25rem;
}
.gradient-text {
  background: var(--grad); -webkit-background-clip:text; -webkit-text-fill-color:transparent;
}
.hero-sub {
  font-size:1.05rem; color:var(--text-dim); max-width:none; margin:0 auto 2.25rem;
  white-space:nowrap;
}
.hero-cta { display:flex; gap:1rem; justify-content:center; flex-wrap:wrap; margin-bottom:3.5rem; }

.hero-stats {
  display:inline-flex; align-items:center; gap:1.75rem;
  padding:1rem 2rem; border-radius:var(--radius);
  background:var(--bg-glass); border:1px solid var(--border);
}
.stat { display:flex; flex-direction:column; }
.stat-num { font-size:1.5rem; font-weight:800; color:var(--gold); line-height:1.2; }
.stat-label { font-size:.75rem; color:var(--text-dim); text-transform:uppercase; letter-spacing:1px; }
.stat-divider { width:1px; height:32px; background:var(--border); }

/* scroll indicator */
.scroll-indicator {
  position:absolute; bottom:2rem; left:50%; transform:translateX(-50%);
  animation: bob 2s ease-in-out infinite;
}
.mouse {
  width:24px; height:38px; border:2px solid var(--gold-dark); border-radius:12px;
  display:flex; justify-content:center; padding-top:6px;
}
.wheel {
  width:3px; height:8px; border-radius:3px; background:var(--gold);
  animation: scroll-wheel 2s ease-in-out infinite;
}
@keyframes bob { 0%,100%{ transform:translateX(-50%) translateY(0); } 50%{ transform:translateX(-50%) translateY(8px); } }
@keyframes scroll-wheel { 0%{ opacity:1; transform:translateY(0); } 100%{ opacity:0; transform:translateY(8px); } }

/* ═══════════════════════════════════════
   SECTION HEADERS
   ═══════════════════════════════════════ */
.section-header { text-align:center; margin-bottom:3.5rem; }
.section-tag {
  display:inline-block; font-size:.75rem; font-weight:700;
  text-transform:uppercase; letter-spacing:2px;
  color: var(--gold);
  margin-bottom:.75rem;
}
.section-header h2 {
  font-family: var(--font-serif);
  font-size:2.6rem; font-weight:600; color:var(--white);
  letter-spacing:0.5px; margin-bottom:.5rem;
}
.section-header p { color:var(--text-dim); max-width:440px; margin:0 auto; }

/* ═══════════════════════════════════════
   DASHBOARD CARDS
   ═══════════════════════════════════════ */
.card-grid {
  display:grid;
  grid-template-columns: repeat(auto-fill, minmax(330px,1fr));
  gap:1.5rem;
}
.card {
  position:relative; overflow:hidden;
  background: var(--bg-card);
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:1.75rem;
  transition: transform .3s, border-color .3s;
  cursor:pointer;
}
.card:hover {
  transform: translateY(-6px);
  border-color: rgba(201,169,110,.25);
}

/* mouse-follow glow */
.card-glow {
  position:absolute; inset:0; pointer-events:none; opacity:0;
  transition: opacity .4s;
  background: radial-gradient(350px circle at var(--mx) var(--my), var(--gold), transparent 70%);
  mix-blend-mode: soft-light;
}
.card:hover .card-glow { opacity:.5; }

.card-top { display:flex; align-items:center; justify-content:space-between; margin-bottom:1rem; }
.card-icon {
  width:44px; height:44px; border-radius:12px;
  display:flex; align-items:center; justify-content:center;
  font-size:1.1rem; color:#0d0d0d;
  background: linear-gradient(135deg, var(--gold), var(--gold-dark));
}
.card-cat {
  font-size:.72rem; font-weight:600; text-transform:uppercase; letter-spacing:1.2px;
  color: var(--gold);
}
.card h3 { font-size:1.15rem; font-weight:700; color:var(--white); margin-bottom:.5rem; }
.card p  { font-size:.88rem; color:var(--text-dim); margin-bottom:1.25rem; }

.card-tools { display:flex; flex-wrap:wrap; gap:.5rem; }
.tool-chip {
  padding:.25rem .7rem; border-radius:50px;
  font-size:.72rem; font-weight:600;
  background: rgba(201,169,110,.08); border:1px solid rgba(201,169,110,.15);
  color:var(--text-dim);
}

/* card view label */
.card-view-label {
  font-size:.78rem; font-weight:600; color:var(--gold);
  margin-top:.5rem; opacity:0; transition: opacity .3s;
  display:flex; align-items:center; gap:.4rem;
}
.card:hover .card-view-label { opacity:1; }

/* ═══════════════════════════════════════
   DASHBOARD MODAL
   ═══════════════════════════════════════ */
.modal-overlay {
  position:fixed; inset:0; z-index:1000;
  background:rgba(0,0,0,.85);
  display:flex; flex-direction:column;
  opacity:0; pointer-events:none;
  transition: opacity .3s;
}
.modal-overlay.open { opacity:1; pointer-events:all; }

.modal-header {
  display:flex; align-items:center; justify-content:space-between;
  padding:.75rem 1.5rem;
  background:rgba(13,13,13,.95);
  border-bottom:1px solid var(--border);
  flex-shrink:0;
}
.modal-title {
  font-family: var(--font-serif);
  font-size:1.1rem; font-weight:600; color:var(--gold);
}
.modal-close {
  background:none; border:1px solid var(--border); border-radius:8px;
  color:var(--text-dim); padding:.4rem 1rem; font-size:.85rem;
  font-family:var(--font); cursor:pointer;
  display:flex; align-items:center; gap:.4rem;
  transition: color .2s, border-color .2s;
}
.modal-close:hover { color:var(--white); border-color:var(--gold); }

.modal-iframe-wrap {
  flex:1; position:relative; overflow:hidden;
}
.modal-iframe {
  position:absolute; top:0; left:0;
  width:1440px; height:100%;
  border:none; background:#fff;
  transform-origin: top left;
}

/* ═══════════════════════════════════════
   CV SECTION
   ═══════════════════════════════════════ */
#cv { background: linear-gradient(180deg, var(--bg) 0%, #0f0e0b 100%); }

.cv-layout {
  display:grid;
  grid-template-columns: 1.4fr 1fr;
  gap:3rem;
  align-items:start;
}

.cv-layout-full {
  max-width: 900px;
  margin: 0 auto;
}

.cv-sub-section {
  margin-top: 5rem;
}
.cv-sub-section .section-header {
  margin-bottom: 2rem;
}

.cv-full-block {
  padding: 2rem;
}
.cv-full-block h4 {
  font-size: .95rem; font-weight: 700; color: var(--white); margin-bottom: 1rem;
  display: flex; align-items: center; gap: .5rem;
}
.cv-full-block h4 i { color: var(--gold); }

.cv-edu-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1.5rem;
}

@media(max-width:640px){
  .cv-edu-grid { grid-template-columns: 1fr; }
}

/* Timeline */
.timeline { position:relative; padding-left:2rem; }
.timeline::before {
  content:''; position:absolute; left:6px; top:8px; bottom:8px;
  width:2px; background: rgba(201,169,110,.15); border-radius:2px;
}
.tl-item { position:relative; margin-bottom:2.5rem; }
.tl-dot {
  position:absolute; left:-2rem; top:6px;
  width:14px; height:14px; border-radius:50%;
  background:var(--bg); border:2px solid var(--gold);
  box-shadow: 0 0 0 4px rgba(201,169,110,.12);
}
.tl-card {
  background:var(--bg-glass); border:1px solid var(--border);
  border-radius:var(--radius); padding:1.5rem;
  transition: border-color .3s;
}
.tl-card:hover { border-color: rgba(201,169,110,.25); }
.tl-year { font-size:.78rem; font-weight:600; color:var(--gold); }
.tl-card h4 { font-size:1.05rem; font-weight:700; color:var(--white); margin:.25rem 0 .15rem; }
.tl-company { font-size:.88rem; color:var(--text-dim); display:block; margin-bottom:.5rem; }
.tl-card p { font-size:.87rem; color:var(--text-dim); }
.tl-bullets {
  list-style: none; padding:0; margin:0;
}
.tl-bullets li {
  font-size:.87rem; color:var(--text-dim); padding-left:1rem;
  position:relative; margin-bottom:.35rem;
}
.tl-bullets li::before {
  content:''; position:absolute; left:0; top:.55em;
  width:5px; height:5px; border-radius:50%;
  background:var(--gold); opacity:.5;
}

/* Aside */
.cv-aside { display:flex; flex-direction:column; gap:1.5rem; }
.aside-block { padding:1.5rem; }
.aside-block h4 {
  font-size:.95rem; font-weight:700; color:var(--white); margin-bottom:1rem;
  display:flex; align-items:center; gap:.5rem;
}
.aside-block h4 i {
  color: var(--gold);
}

.skill-cloud { display:flex; flex-wrap:wrap; gap:.45rem; }
.skill-pill {
  padding:.3rem .8rem; border-radius:50px;
  font-size:.78rem; font-weight:600;
  background:rgba(201,169,110,.1); border:1px solid rgba(201,169,110,.18);
  color:var(--gold-light);
  transition: background .2s, border-color .2s;
}
.skill-pill:hover { background:rgba(201,169,110,.2); border-color:rgba(201,169,110,.35); }

.edu-degree { font-size:1rem; font-weight:700; color:var(--white); }
.edu-concentration { font-size:.88rem; color:var(--gold-light); margin-bottom:.2rem; }
.edu-school { font-size:.88rem; color:var(--gold); margin-bottom:.5rem; }
.edu-detail { font-size:.85rem; color:var(--text-dim); font-style:italic; }

@media(max-width:800px){
  .cv-layout { grid-template-columns:1fr; }
}

/* ═══════════════════════════════════════
   TESTIMONIALS
   ═══════════════════════════════════════ */
#testimonials { background: linear-gradient(180deg, #0f0e0b 0%, var(--bg) 100%); }

.testimonial-grid {
  display:grid;
  grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
  gap:1.5rem;
}

.testimonial-empty {
  padding:3rem 0;
  font-size:1rem;
}

.testimonial-card {
  padding:2rem;
  position:relative;
}

.testimonial-quote-icon {
  font-size:1.4rem;
  color:var(--gold);
  opacity:.4;
  margin-bottom:.75rem;
  display:block;
}
.testimonial-quote-close {
  text-align:right;
  margin-bottom:0;
  margin-top:.75rem;
}

.testimonial-quote {
  font-size:.95rem;
  color:var(--text);
  line-height:1.7;
  font-style:italic;
  margin-bottom:1.25rem;
}

.testimonial-author {
  border-top:1px solid var(--border);
  padding-top:.75rem;
}

.testimonial-name {
  font-size:.9rem;
  font-weight:700;
  color:var(--white);
}

.testimonial-title {
  font-size:.8rem;
  color:var(--gold);
  margin-top:.15rem;
}

.testimonial-form-wrap {
  max-width:720px;
  margin:0 auto;
  margin-top:3rem;
}

.testimonial-form-title {
  font-family:var(--font-serif);
  font-size:1.5rem;
  font-weight:600;
  color:var(--white);
  text-align:center;
  margin-bottom:1.5rem;
}

@media(max-width:640px){
  .testimonial-grid { grid-template-columns:1fr; }
  .testimonial-card { padding:1.25rem; }
  .testimonial-form-title { font-size:1.2rem; }
}

/* ═══════════════════════════════════════
   CONTACT
   ═══════════════════════════════════════ */
#contact { position:relative; }

.contact-form { padding:2.5rem; margin-bottom:2rem; }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:1rem; }
.form-group { margin-bottom:1.1rem; }
.form-group label {
  display:block; font-size:.82rem; font-weight:600; color:var(--text-dim);
  margin-bottom:.4rem;
}
.req { color:#c9a96e; }
.form-group input,
.form-group textarea {
  width:100%; padding:.75rem 1rem;
  border:1px solid var(--border); border-radius:var(--radius-sm);
  background:rgba(201,169,110,.03); color:var(--white);
  font-size:.92rem; font-family:var(--font);
  transition: border-color .25s, box-shadow .25s;
}
.form-group input::placeholder,
.form-group textarea::placeholder { color:var(--text-dim); }
.form-group input:focus,
.form-group textarea:focus {
  outline:none; border-color:var(--gold);
  box-shadow: 0 0 0 3px rgba(201,169,110,.12);
}
.form-group textarea { resize:vertical; }

.form-status { margin-top:1rem; font-size:.88rem; text-align:center; min-height:1.4em; }
.form-status.success { color:#c9a96e; }
.form-status.error   { color:#f87171; }

.contact-links {
  display:flex; gap:1rem; flex-wrap:wrap; justify-content:center;
}
.contact-chip {
  display:inline-flex; align-items:center; gap:.5rem;
  padding:.65rem 1.25rem; font-size:.88rem; font-weight:500;
  color:var(--text-dim); transition: color .2s, border-color .2s;
}
.contact-chip:hover { color:var(--gold); border-color:rgba(201,169,110,.3); }
.contact-chip i { font-size:1rem; }

@media(max-width:640px){
  .form-row { grid-template-columns:1fr; }
  .contact-form { padding:1.5rem; }
}

/* ═══════════════════════════════════════
   FOOTER
   ═══════════════════════════════════════ */
footer {
  text-align:center; padding:2.5rem 1.5rem;
  border-top:1px solid var(--border);
  font-size:.82rem; color:var(--text-dim);
}

/* ═══════════════════════════════════════
   SCROLL REVEAL
   ═══════════════════════════════════════ */
.reveal {
  opacity:0; transform:translateY(28px);
  transition: opacity .7s cubic-bezier(.16,1,.3,1), transform .7s cubic-bezier(.16,1,.3,1);
}
.reveal.visible { opacity:1; transform:translateY(0); }

/* staggered cards */
.card.reveal:nth-child(2) { transition-delay:.08s; }
.card.reveal:nth-child(3) { transition-delay:.16s; }
.card.reveal:nth-child(4) { transition-delay:.24s; }
.card.reveal:nth-child(5) { transition-delay:.32s; }
.card.reveal:nth-child(6) { transition-delay:.40s; }

/* ═══════════════════════════════════════
   RESPONSIVE TWEAKS
   ═══════════════════════════════════════ */

/* Tablet */
@media(max-width:900px){
  .cv-edu-grid { grid-template-columns:1fr; }
  .cv-layout-full { max-width:100%; }
}

/* Mobile */
@media(max-width:640px){
  section { padding:4rem 0; }

  /* Navbar */
  .nav-logo-img { height:48px; }
  .nav-linkedin { display:none !important; }
  .nav-links.open .nav-linkedin { display:inline-flex !important; }

  /* Hero */
  #hero { padding:calc(var(--nav-h) + 1rem) 1rem 3rem; }
  #hero h1 { font-size:2rem; letter-spacing:0; }
  .hero-headshot { width:120px; height:120px; margin-bottom:1.5rem; }
  .hero-badge { font-size:.6rem; letter-spacing:1px; padding:.35rem .9rem; white-space:normal; max-width:90%; }
  .hero-sub { white-space:normal !important; font-size:.95rem; max-width:100%; padding:0 .5rem; }
  .hero-cta { flex-direction:column; align-items:center; gap:.75rem; }
  .hero-cta .btn { width:100%; max-width:280px; }

  /* Section headers */
  .section-header h2 { font-size:1.7rem; }
  .section-tag { font-size:.68rem; }

  /* Dashboard cards */
  .card-grid { grid-template-columns:1fr; }
  .card { padding:1.25rem; }

  /* CV */
  .timeline { padding-left:1.5rem; }
  .tl-card { padding:1.1rem; }
  .tl-card h4 { font-size:.95rem; }
  .tl-card p { font-size:.82rem; }
  .cv-sub-section { margin-top:3.5rem; }
  .cv-full-block { padding:1.25rem; }
  .skill-pill { font-size:.72rem; padding:.25rem .65rem; }

  /* Education */
  .cv-edu-grid { grid-template-columns:1fr; }
  .edu-degree { font-size:.9rem; }

  /* Contact */
  .contact-form { padding:1.25rem; }
  .form-row { grid-template-columns:1fr; }

  /* Modal */
  .modal-header { padding:.5rem 1rem; }
  .modal-title { font-size:.9rem; }
  .modal-close { font-size:.78rem; padding:.3rem .75rem; }

  /* General */
  .hero-logo { width: 160px; }
  .hero-stats { flex-direction:column; gap:.75rem; padding:1rem 1.5rem; }
  .stat-divider { width:40px; height:1px; }
}
