/* Base variables and reset */
:root{
  --bg: #0a0a0b;
  --panel: #0f0f10;
  --text: #e9f0f2;
  --muted: #9aa6ac;
  --accent: #FFB400; /* gold/orange accent to match request */
  --gold: #B8860B; /* preserved for existing elements */
  --max-width: 1200px;

  /* Typography scale */
  --base: 16px;
  --fs-display: 8rem; /* visual display */
  --fs-xl: 3rem; /* section headings */
  --fs-lg: 1.125rem; /* lead text */
  --fs-md: 1rem; /* body */
  --lh-base: 1.6;
  --lh-heading: 1.05;
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{
  font-family: "Inter", system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial;
  font-size:var(--base);
  background:var(--bg);
  color:var(--text);
  line-height:var(--lh-base);
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  overflow-x:hidden;
  -webkit-font-feature-settings: "kern" 1;
}
/* Navigation */
nav{position:fixed;top:0;width:100%;background:linear-gradient(180deg, rgba(0,0,0,0.75), rgba(0,0,0,0.45));padding:14px 28px;z-index:1000;display:flex;justify-content:space-between;align-items:center}
nav h1{font-family:"Montserrat", "Inter", sans-serif !important;font-weight:900 !important;letter-spacing:0.5px !important;font-size:1.1rem !important;margin:0 !important;line-height:normal !important}
nav ul{list-style:none;display:flex;gap:18px}
nav a{color:var(--muted);text-decoration:none;font-weight:600;transition:color .2s ease}
nav a:hover{color:var(--text)}

/* Site title hover/focus */
nav h1 a{color:var(--text) !important;text-decoration:none !important;font-weight:900 !important;font-family:"Montserrat", "Inter", sans-serif !important;transition:color .18s ease}
nav h1 a:hover, nav h1 a:focus{color:var(--accent);text-decoration:underline;outline:none}
nav h1 a:focus{box-shadow:0 0 0 3px rgba(255,180,0,0.12);border-radius:3px}

/* Hero / Parallax */
.hero{min-height:100vh;display:flex;align-items:center;justify-content:center;position:relative;padding-top:0;perspective:1200px;transform-style:preserve-3d}
.project .hero{min-height:auto;padding:24px 0;display:block}
.layer{position:absolute;inset:0;pointer-events:none;will-change:transform;transform:translateZ(0);transform-style:preserve-3d}
.project .hero .layer{position:relative;inset:auto}
.hero .layer img{display:block;max-width:100%;height:auto;margin:0 auto}

/* Centered hero content */
.hero-content{position:absolute;top:50%;left:50%;transform:translate(-50%, -50%) !important;z-index:10;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:0 20px;transition:opacity .28s ease;will-change:opacity}
.hero-content h1{margin:0;white-space:nowrap}
.hero-content .lead{opacity:1;margin-top:12px;margin-bottom:6px}
.hero-content .text-muted{margin-top:4px}
.scroll-arrow{margin-top:28px;color:var(--accent);font-size:2.4rem;cursor:pointer} 

/* Hide nav on arrival and reveal on scroll */
nav{transition:opacity .35s ease, transform .35s ease}
body.hero-first nav{opacity:0;transform:translateY(-12px);pointer-events:none}
body:not(.hero-first) nav{opacity:1;pointer-events:auto}

/* Ensure content below hero isn't visible until user scrolls */
body.hero-first .section{opacity:0;pointer-events:none;user-select:none}

/* When user scrolls, sections will be revealed via existing scroll logic */

/* Initial load: hide UI details so only hero is visible */
body.hero-first nav{opacity:0;transform:translateY(-12px);pointer-events:none}
body.hero-first .section, body.hero-first .contact, body.hero-first .projects-grid{visibility:hidden}
body.hero-first .scroll-arrow{opacity:1}

/* Smooth reveal of nav */
nav{transition:opacity .32s ease, transform .28s cubic-bezier(.2,.9,.2,1)}
nav.visible{opacity:1;transform:translateY(0);pointer-events:auto}

.floating-shape{position:absolute;border-radius:50%;background:linear-gradient(135deg, rgba(255,255,255,0.03), rgba(255,255,255,0.01));filter:blur(80px);opacity:.8;pointer-events:none}
.shape1{width:380px;height:380px;top:10%;left:6%;}
.shape2{width:240px;height:240px;bottom:12%;right:6%}
.hero h1{font-family:"Montserrat",sans-serif;font-weight:900;font-size:clamp(1.8rem, 10vw, 6rem);letter-spacing:6px;text-transform:uppercase;color:var(--text);line-height:var(--lh-heading);margin-bottom:6px;opacity:0;transform:translateY(30px);animation:fadeInUp .9s cubic-bezier(.2,.9,.2,1) forwards .4s} 
.hero p{font-size:1.125rem;color:var(--muted);opacity:0;transform:translateY(30px);animation:fadeInUp .9s cubic-bezier(.2,.9,.2,1) forwards .7s}
.scroll-arrow{font-size:2rem;color:var(--accent);margin-top:28px;animation:bounce 2s infinite}
@keyframes bounce{0%,20%,50%,80%,100%{transform:translateY(0)}40%{transform:translateY(-12px)}60%{transform:translateY(-6px)}}
@keyframes fadeInUp{to{opacity:1;transform:translateY(0)}}

/* Sections */
.section{padding:120px 24px;max-width:var(--max-width);margin:0 auto;opacity:0;transform:translateY(40px);transition:opacity .3s ease,transform .3s ease}
/* Tighten spacing specifically for the work section (visually replace the removed heading)
   and make it more compact on smaller screens */
#work.section{padding-top:64px;padding-bottom:80px}
@media (max-width:900px){#work.section{padding-top:48px;padding-bottom:60px}}

/* Related work block */
.related-work{margin-top:48px;border-top:1px solid rgba(255,255,255,0.03);padding-top:28px}
.related-work h3{margin:0 0 12px;font-size:1rem;color:var(--muted);text-transform:uppercase;letter-spacing:.08em}
.related-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.related-card{display:block;background:linear-gradient(180deg, rgba(255,255,255,0.02), rgba(0,0,0,0.06));padding:10px;border-radius:8px;text-align:center;color:var(--text);text-decoration:none}
.related-card img{width:100%;height:78px;min-height:78px;max-height:78px;object-fit:cover;border-radius:6px;display:block}
.related-card .label{display:block;margin-top:8px;font-weight:600;font-size:.95rem}
@media (max-width:700px){.related-grid{grid-template-columns:repeat(2,1fr)} .related-card img{height:64px}}
@media (max-width:420px){.related-grid{grid-template-columns:1fr} .related-card{display:flex;gap:12px;align-items:center} .related-card img{width:86px;height:56px;flex:0 0 86px} .related-card .label{text-align:left}}

.section.visible{opacity:1;transform:translateY(0)}
.section h2{font-family:"Montserrat",sans-serif;font-size:clamp(1.6rem, 4vw, 3rem);letter-spacing:2px;text-transform:uppercase;margin-bottom:18px;color:var(--text);line-height:var(--lh-heading)}
.section p{color:var(--muted);font-size:var(--fs-lg)}
.lead{font-size:var(--fs-lg);color:var(--text);opacity:.95;line-height:1.5;margin-bottom:18px}

/* Projects grid */
.projects-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:22px;margin:24px 0 60px}
.project-card{background:linear-gradient(180deg, rgba(255,255,255,0.02), rgba(0,0,0,0.15));padding:18px;border-radius:12px;text-align:center;color:var(--text);overflow:hidden;transform:translateY(40px);opacity:0;transition:transform .3s cubic-bezier(.2,.9,.2,1),opacity .3s ease}
.project-card.visible{transform:translateY(0);opacity:1}
.project-card img{width:100%;height:200px;object-fit:cover;border-radius:6px;display:block}
.project-card{background:linear-gradient(180deg, rgba(255,255,255,0.02), rgba(0,0,0,0.15));padding:18px;border-radius:12px;text-align:left;color:var(--text);overflow:hidden;transform:translateY(40px);opacity:0;transition:transform .3s cubic-bezier(.2,.9,.2,1),opacity .3s ease;text-decoration:none}
.project-card.visible{transform:translateY(0);opacity:1}
.project-card img{width:100%;height:200px;object-fit:cover;border-radius:6px;display:block}
.project-card h3{margin:0;font-size:1.05rem;display:flex;justify-content:space-between;align-items:center;text-decoration:none}
.project-card .year{font-size:.78rem;color:var(--muted);font-weight:600;margin-left:8px}
.project-card .subtitle{margin-top:4px;color:var(--muted);font-size:.92rem;margin-bottom:0;text-decoration:none}
.project-card .project-card-content{margin-top:8px}
/* Ensure links inside project cards don't show underlines */
.project-card, .project-card * {text-decoration:none !important}

/* Confidential badge overlay */
.project-card{position:relative}
.confidential-badge{position:absolute;top:28px;right:28px;background:rgba(0,0,0,0.85);backdrop-filter:blur(8px);padding:6px 12px;border-radius:6px;display:flex;align-items:center;gap:6px;font-size:0.75rem;font-weight:600;color:var(--text);letter-spacing:0.5px;border:1px solid rgba(255,255,255,0.15);z-index:10}
.confidential-badge svg{width:14px;height:14px;fill:var(--accent)}

/* Case study title/subtitle style */
.project .case-title{font-family:"Montserrat",sans-serif;font-weight:700;font-size:clamp(1.8rem,4.6vw,2.6rem);color:var(--text);margin:0 0 6px;line-height:1;letter-spacing:.6px}
.project .case-subtitle{color:var(--muted);font-size:1rem;margin:0 0 18px;opacity:.95;font-weight:400}

/* Case study section headers (bold, impactful H2-style with generous spacing) */
.project .case-section{font-family:"Montserrat",sans-serif;font-weight:800;font-size:clamp(1.75rem,3.2vw,2.25rem);color:var(--text);margin:200px 0 32px;letter-spacing:.8px;line-height:1.2;scroll-margin-top:120px}
.project .case-section:first-of-type{margin-top:48px}
/* Reduce top margin when case-section follows an eyebrow */
.project .eyebrow + .case-section{margin-top:4px !important}

/* Emphasized blockquote styling */
.emphasized-quote{font-family:"Montserrat",sans-serif;font-weight:600;font-size:clamp(1.5rem,2.8vw,2rem);color:var(--text);font-style:italic;margin:48px 0;padding:32px 48px;background:linear-gradient(135deg, rgba(255,180,0,0.08), rgba(255,255,255,0.02));border-left:4px solid var(--accent);border-radius:8px;line-height:1.4}
.emphasized-quote::before{content:'"';color:var(--accent);font-size:3rem;line-height:0;margin-right:8px}
.emphasized-quote::after{content:'"';color:var(--accent);font-size:3rem;line-height:0;margin-left:8px}

/* Parallax scene containers in case studies */
.parallax-scene{margin:80px 0;position:relative;overflow:hidden}
.parallax-scene .layer{position:relative;inset:auto}
.parallax-scene .layer img{display:block;max-width:100%;height:auto;margin:0 auto}
.parallax-scene.align-right .layer img{margin:0 0 0 auto !important}

/* New project layout: full-width sections with two-column top */
.project{max-width:var(--max-width);margin:0 auto;padding:48px 20px}
.project img{max-width:100%;height:auto;display:block;margin:24px 0}
.project-top{display:grid;grid-template-columns:1fr 320px;gap:36px;align-items:start;margin-bottom:28px}
@media (max-width:880px){.project-top{grid-template-columns:1fr;gap:18px}}
.project-main{min-width:0}
.project-meta{background:linear-gradient(180deg, rgba(255,255,255,0.02), rgba(0,0,0,0.12));padding:18px;border-radius:12px}
.project-meta .meta-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px}
.project-meta .meta-list li{display:flex;justify-content:space-between;align-items:center;gap:12px;color:var(--muted);font-size:.95rem}
.project-meta .meta-list strong{color:var(--text);font-weight:700}

/* Results / metrics grid (seeing results) */
.project-results{margin-top:12px;padding-top:24px;border-top:1px solid rgba(255,255,255,0.03)}
.project-results h3{font-family:"Montserrat",sans-serif;font-size:1.25rem;color:var(--text);margin:0 0 12px}
.results-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:14px}
.result-card{background:linear-gradient(180deg, rgba(255,255,255,0.02), rgba(0,0,0,0.06));padding:18px;border-radius:8px;display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:88px}
.result-card .value{font-weight:800;font-size:1.25rem;color:var(--text);margin-bottom:6px}
.result-card .label{font-size:.9rem;color:var(--muted);text-align:center}

@media (max-width:480px){.project{padding:22px 14px}.project-meta{padding:12px}.result-card{min-height:72px}}

/* GIF Controls */
.gif-wrapper{position:relative;display:inline-block;max-width:100%}
.gif-control-btn{position:absolute;bottom:12px;right:12px;background:rgba(0,0,0,0.75);border:2px solid rgba(255,255,255,0.3);color:var(--text);padding:8px 12px;border-radius:6px;cursor:pointer;font-size:1.2rem;line-height:1;transition:all 0.2s ease;backdrop-filter:blur(4px);z-index:10}
.gif-control-btn:hover{background:rgba(0,0,0,0.9);border-color:var(--accent);transform:scale(1.1)}
.gif-control-btn:focus{outline:2px solid var(--accent);outline-offset:2px}

/* Contact */
.contact{padding:80px 24px;text-align:center}
.contact a{color:var(--accent);text-decoration:none;font-weight:600}

/* Resume page layout */
.about-hero{display:grid;grid-template-columns:200px 1fr;gap:24px;align-items:center;margin:32px 0 28px;padding:20px 22px;background:linear-gradient(135deg, rgba(255,180,0,0.12), rgba(255,255,255,0.04));border:1px solid rgba(255,255,255,0.08);border-radius:14px;box-shadow:0 18px 40px rgba(0,0,0,0.35)}
.headshot-link{display:block;text-decoration:none}
.headshot-frame{width:180px;height:180px;border-radius:50%;padding:8px;background:linear-gradient(145deg, rgba(255,180,0,0.85), rgba(255,180,0,0.25));display:grid;place-items:center;box-shadow:0 12px 32px rgba(0,0,0,0.35)}
.headshot-inner{width:100%;height:100%;border-radius:50%;overflow:hidden;background:radial-gradient(circle at 30% 30%, rgba(255,255,255,0.08), rgba(0,0,0,0.65));border:1px solid rgba(255,255,255,0.08)}
.headshot-inner img{width:120%;height:120%;object-fit:cover;object-position:center 35%;display:block;filter:saturate(1.05) contrast(1.05);transform:scale(1.18) translateY(-10px)}
/* Universal eyebrow style - consistent across all pages */
.eyebrow{font-size:0.9rem;letter-spacing:0.08em;text-transform:uppercase;color:#FFB400 !important;margin:0 0 2px;font-weight:700;display:block}
.project .eyebrow{color:#FFB400 !important}
.project .eyebrow:not(:first-of-type){margin-top:200px}
.about-copy h2{margin:0 0 12px;font-size:1.6rem;color:var(--text);font-family:"Montserrat",sans-serif;letter-spacing:.4px}
.about-copy p{margin:0;color:var(--muted);font-size:1rem;line-height:1.6}

.resume-grid{display:grid;grid-template-columns:1fr 180px;gap:32px;max-width:100%;margin:0 auto;width:100%}
.resume-left{display:none}
.resume-left .name{font-family:"Montserrat",sans-serif;font-weight:900;font-size:2.05rem;margin-bottom:6px}
.resume-left .headline{color:var(--muted);margin-bottom:10px;font-size:0.95rem}
.resume-left .resume-contact p{margin:8px 0;color:var(--text);font-size:.95rem}
.resume-left .resume-contact a{color:var(--accent);text-decoration:none}
.resume-left .summary{margin-top:14px;color:var(--text);line-height:1.45;font-size:0.98rem}
.resume-right{background:linear-gradient(180deg, rgba(255,255,255,0.02), rgba(0,0,0,0.04));padding:22px 24px;border-radius:8px;width:100%;grid-column:1}
.resume-right .resume-section{margin-bottom:18px}
.resume-right h3{font-family:"Montserrat",sans-serif;font-size:1.02rem;color:var(--text);margin:0 0 8px;font-weight:700;letter-spacing:.4px}

/* Skills sidebar */
.resume-grid > .resume-section:not(.resume-experience){grid-column:2;grid-row:1;padding:0}
.resume-grid > .resume-section:not(.resume-experience) .label{font-size:0.85rem;text-transform:uppercase;letter-spacing:0.05em;margin-bottom:12px;color:var(--accent);font-weight:700}
.resume-grid > .resume-section:not(.resume-experience) .skills{list-style:none;margin:0;padding:0;font-size:0.75rem;line-height:1.4}
.resume-grid > .resume-section:not(.resume-experience) .skills li{margin-bottom:8px;color:var(--muted)}

/* Experience section spans full width */
.resume-experience{grid-column:1 / -1 !important;width:100% !important;margin-left:0 !important;margin-right:0 !important}

/* Resume table layout (label/date/company/role rows) */
.resume-table{display:block}
.resume-table .row{display:grid;grid-template-columns:200px 1fr;gap:24px;align-items:start;padding:20px 0;border-bottom:1px solid rgba(255,255,255,0.06)}
.resume-table .row:last-child{border-bottom:none}
.resume-table .left-col{display:flex;flex-direction:column;gap:6px}
.resume-table .col-date{color:var(--muted);font-weight:400;font-size:.92rem;font-variant-numeric:tabular-nums}
.resume-table .col-company{font-weight:700;color:var(--text);font-size:1rem}
.resume-table .col-role{font-weight:600;color:var(--text);font-size:0.95rem}
.resume-table .col-description{color:var(--muted);font-weight:400;font-size:0.98rem;line-height:1.45}

/* Small screen: stack rows */
@media (max-width:700px){
  .about-hero{grid-template-columns:1fr;text-align:center}
  .headshot-frame{margin:0 auto}
  .resume-grid{grid-template-columns:1fr;padding:0 18px}
  .resume-right{margin-top:18px}
  .resume-table .row{grid-template-columns:1fr}
  .resume-table .col-date{margin-bottom:8px}
  .resume-table .col-company{font-size:1rem}
  .resume-table .col-role{font-size:.96rem}
  .resume-left .name{font-size:1.75rem}
  .resume-left .headline{font-size:.92rem}
}

/* preserve some of the traditional job styles for older content */
.job{margin-bottom:12px;break-inside:avoid-page}
.job-title{font-weight:700;color:var(--text);margin-bottom:6px;font-size:1rem}
.job-meta{display:block;color:var(--muted);font-weight:600;font-size:.9rem;margin-top:2px}
.job p{color:var(--muted);margin:6px 0}
.job ul{margin:8px 0 0 20px;color:var(--muted)}
.skills{list-style:disc;margin-left:18px;color:var(--muted)}
.resume-download{display:inline-block;margin-top:12px;padding:10px 14px;border-radius:8px;background:linear-gradient(90deg,var(--accent),var(--gold));color:#071013;font-weight:700;text-decoration:none}
.resume-contact p{margin:6px 0}
.muted.small{color:var(--muted);font-size:.95rem}

/* Print styles for PDF export (Letter size) */
@media print {
  /* Letter-sized documents with comfortable margins */
  @page { size: Letter; margin: 0.75in; }
  :root{background:#fff;color:#071013}
  body{background:#fff;color:#071013}
  .resume-right{background:#fff;padding:0;border-radius:0}
  .resume-left{border-right:none;padding:0}
  .project_title, nav, .cargo_link, .thumbnails, .site_footer, .project_nav_wrapper, .loading{display:none}
  .container, .resume-grid{max-width:560px;margin:18px auto;grid-template-columns:1fr}
  .resume-left .name{color:#071013}
  .resume-left .headline{color:#071013}
  .resume-right h3{color:#071013}
  a{color:#071013;text-decoration:underline}
  .job{page-break-inside:avoid}
  /* ensure date remains legible on paper */
  .resume-table .col-date{color:#071013}
}

@media (max-width:880px){.resume-grid{grid-template-columns:1fr;padding:0 18px}.resume-right{margin-top:18px}}

/* Utility */
.text-muted{color:var(--muted)}
.container{max-width:var(--max-width);margin:0 auto;padding:0 20px}

/* Hide size selector and other Cargo UI elements */
.parallax-controls,
[class*="elementResizer"],
.resize-handle,
.size-selector,
[data-elementresizer] > *:last-child,
.project_content > div:last-child,
body .elementResizer,
.element-resizer,
div[class*="resize"],
button[class*="size"],
span[class*="size"],
.entry svg,
.entry button,
.retinaSpinner{display:none !important;visibility:hidden !important}

/* Hide positioned elements over content */
.project_content {position: relative;overflow:hidden;}
.project_content ~ *:not(.project_nav_wrapper):not(.thumbnails):not(.site_footer) {display:none !important;}

/* Accessible visually-hidden utility */
.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}

/* Responsive */
@media (max-width:900px){
  .hero h1{font-size:3.4rem}
  .section{padding:80px 18px}
  .shape1{width:240px;height:240px;left:-10%}
  .shape2{width:140px;height:140px}
}
@media (max-width:480px){
  nav h1{font-size:1rem}
  .hero h1{font-size:2rem}
  .projects-grid{gap:14px}
}

/* Parallax controls */
.parallax-controls{position:fixed;right:18px;bottom:18px;background:linear-gradient(180deg, rgba(0,0,0,0.5), rgba(0,0,0,0.35));padding:6px;border-radius:28px;display:flex;gap:6px;z-index:2000;backdrop-filter:blur(6px)}
.parallax-controls button{width:36px;height:36px;border-radius:20px;border:0;background:rgba(255,255,255,0.03);color:var(--text);font-weight:700;cursor:pointer;transition:transform .18s ease,box-shadow .18s ease}
.parallax-controls button.active{background:linear-gradient(90deg,var(--accent),var(--gold));color:#071013;box-shadow:0 8px 22px rgba(0,0,0,0.6);transform:translateY(-2px)}
.parallax-controls button:focus{outline:2px solid rgba(255,255,255,0.08)}

/* Per-layer controls panel */
.parallax-layer-panel{position:absolute;right:0;bottom:56px;background:linear-gradient(180deg,rgba(0,0,0,0.55),rgba(0,0,0,0.4));padding:10px;border-radius:10px;min-width:220px;box-shadow:0 6px 20px rgba(0,0,0,0.6);display:flex;flex-direction:column;gap:8px;z-index:2100}
.parallax-layer-panel .layer-row{display:flex;align-items:center;gap:8px}
.parallax-layer-panel label{flex:1;color:var(--muted);font-size:0.86rem}
.parallax-layer-panel input[type="range"]{width:110px}
.parallax-layer-panel .layer-value{min-width:36px;text-align:right;color:var(--text);font-size:0.9rem}

/* Floating shapes animation */
@keyframes floaty{0%{transform:translateY(0) translateX(0) rotate(0)}50%{transform:translateY(-12px) translateX(6px) rotate(2deg)}100%{transform:translateY(0) translateX(0) rotate(0)}}
.floating-shape{animation:floaty 10s ease-in-out infinite}

/* Card hover */
.project-card:hover{transform:translateY(-8px) scale(1.02);box-shadow:0 18px 40px rgba(0,0,0,0.55)}

/* Link underline */
.underline-link{position:relative;display:inline-block}
.underline-link:after{content:'';position:absolute;left:0;bottom:-4px;height:2px;width:100%;background:linear-gradient(90deg,var(--accent),var(--gold));transform:scaleX(0);transform-origin:left center;transition:transform .25s ease}
.underline-link:hover:after{transform:scaleX(1)}

/* Focused small animations */
a{transition:opacity .2s ease, transform .15s ease}
a:hover{transform:translateY(-3px)}

/* Fallback for older browsers */
.no-js .section{opacity:1;transform:none}
