/* Resume page layout */
@layer components {
  .resume-section{
    padding:clamp(2.4rem, 6vw, 3.8rem) 0;
  }
  .resume-eyebrow{
    margin:0;
    text-transform:uppercase;
    letter-spacing:.25em;
    font-size:.72rem;
    color:var(--text-muted);
  }

  .resume-paper{
    max-width:980px;
    margin:0 auto;
    padding:clamp(1.4rem, 3vw, 2.2rem);
    border-radius:20px;
    border:1px solid color-mix(in srgb,var(--primary) 22%, transparent);
    background:linear-gradient(180deg,
      color-mix(in srgb,var(--surface) 96%, #ffffff 4%) 0%,
      color-mix(in srgb,var(--surface) 90%, #02070d 10%) 100%);
    box-shadow:0 26px 64px rgba(0,0,0,.38);
    position:relative;
    overflow:hidden;
  }
  .resume-paper::before{
    content:"";
    position:absolute;
    left:0;
    right:0;
    top:0;
    height:6px;
    background:linear-gradient(90deg,
      color-mix(in srgb,var(--primary) 80%, #ffffff 20%) 0%,
      color-mix(in srgb,var(--primary) 40%, #071219 60%) 100%);
  }

  .resume-paper-header{
    padding-top:8px;
  }

  .resume-top{
    margin-top:10px;
    display:flex;
    align-items:flex-start;
    justify-content:space-between;
    gap:14px 20px;
    flex-wrap:wrap;
  }

  .resume-identity{
    display:grid;
    gap:8px;
    min-width:min(360px, 100%);
  }

  .resume-name{
    margin:0;
    font-family:'Poppins';
    font-size:clamp(2.2rem, 4vw, 3.05rem);
    line-height:1.05;
    color:var(--text-light);
    letter-spacing:.01em;
  }
  .resume-title{
    margin:0;
    font-size:.95rem;
    letter-spacing:.18em;
    text-transform:uppercase;
    color:color-mix(in srgb,var(--primary) 92%, #ffffff 8%);
    font-weight:700;
  }

  .resume-actions{
    display:flex;
    flex-wrap:wrap;
    gap:12px;
    align-items:center;
  }

	  .resume-contact-grid{
	    margin-top:16px;
	    display:grid;
	    grid-template-columns:repeat(3, minmax(0, 1fr));
	    gap:12px;
	  }
	  @media (max-width: 840px){
	    .resume-contact-grid{
	      grid-template-columns:repeat(2, minmax(0, 1fr));
	    }
	  }
	  @media (max-width: 520px){
	    .resume-contact-grid{
	      grid-template-columns:1fr;
	    }
	  }
	  .resume-contact-item{
	    display:inline-flex;
	    align-items:center;
	    gap:8px;
	    box-sizing:border-box;
	    padding:8px 12px;
	    border-radius:14px;
	    border:1px solid color-mix(in srgb,var(--text-light) 10%, transparent);
	    background:transparent;
	    color:color-mix(in srgb,var(--text-light) 88%, #ffffff 12%);
    font-size:.92rem;
    letter-spacing:.01em;
    line-height:1.3;
	    width:100%;
	    justify-content:flex-start;
	    min-width:0;
	    overflow-wrap:anywhere;
	  }
  a.resume-contact-item{
    text-decoration:none;
    transition:transform .15s ease, border-color .15s ease, background-color .15s ease;
  }
  a.resume-contact-item:hover{
    transform:translateY(-1px);
    border-color:color-mix(in srgb,var(--primary) 32%, transparent);
    background:color-mix(in srgb,var(--surface) 94%, #000 6%);
  }
  .resume-contact-item svg{
    width:18px;
    height:18px;
    stroke:currentColor;
    fill:none;
    stroke-width:2;
    stroke-linecap:round;
    stroke-linejoin:round;
    flex-shrink:0;
  }
  .resume-contact-item .icon-fill{
    fill:currentColor;
    stroke:none;
  }

  .resume-summary{
    margin:18px 0 0;
    color:var(--text-light);
    max-width:78ch;
    line-height:1.7;
  }

  .resume-highlights{
    margin-top:16px;
    display:grid;
    gap:12px;
    grid-template-columns:repeat(3, minmax(0, 1fr));
  }
  .resume-highlight{
    padding:12px 14px;
    border-radius:16px;
    border:1px solid color-mix(in srgb,var(--text-light) 10%, transparent);
    background:transparent;
    display:grid;
    gap:6px;
  }
  .resume-highlight-value{
    font-family:'Poppins';
    font-weight:700;
    color:color-mix(in srgb,var(--primary) 80%, #ffffff 20%);
    font-size:1.25rem;
    letter-spacing:.01em;
  }
  .resume-highlight-label{
    color:var(--text-muted);
    font-size:.92rem;
    line-height:1.4;
  }

	  .resume-body{
	    margin-top:22px;
	    display:grid;
	    grid-template-columns:minmax(0, 340px) minmax(0, 1fr);
	    gap:26px;
	    align-items:stretch;
	  }

	  .resume-side,
	  .resume-main{
	    display:grid;
	    gap:18px;
	    align-content:start;
	  }
  .resume-main{
    padding-left:22px;
    border-left:1px solid color-mix(in srgb,var(--text-light) 10%, transparent);
  }

  .resume-block{
    padding-top:16px;
    border-top:1px solid color-mix(in srgb,var(--text-light) 10%, transparent);
  }
  .resume-block:first-child{
    padding-top:0;
    border-top:none;
  }
	  .resume-block-title{
	    margin:0 0 12px;
	    font-family:'Poppins';
	    font-size:1.15rem;
	    letter-spacing:.01em;
	    color:var(--text-light);
	  }
	  .resume-projects-wide{
	    grid-column:1 / -1;
	  }
	  .resume-wide-category{
	    display:flex;
	    align-items:center;
	    gap:14px;
	    justify-content:center;
	  }
	  .resume-wide-category::before,
	  .resume-wide-category::after{
	    content:"";
	    flex:1;
	    height:1px;
	    background:color-mix(in srgb,var(--text-light) 10%, transparent);
	  }
	  .resume-wide-category span{
	    white-space:nowrap;
	  }
  .resume-subhead{
    margin:16px 0 10px;
    font-size:.92rem;
    text-transform:uppercase;
    letter-spacing:.16em;
    color:var(--text-muted);
  }
  .resume-skill-group:first-of-type .resume-subhead{
    margin-top:0;
  }
  .resume-chip-list{
    list-style:none;
    padding:0;
    margin:0;
    display:grid;
    grid-template-columns:1fr;
    gap:8px;
  }
  .resume-chip{
    padding:8px 10px;
    border-radius:12px;
    border:1px solid color-mix(in srgb,var(--text-light) 10%, transparent);
    background:transparent;
    color:color-mix(in srgb,var(--text-light) 92%, #ffffff 8%);
    font-size:.9rem;
    font-weight:600;
  }

  .resume-cert-grid{
    list-style:none;
    padding:0;
    margin:0;
    display:grid;
    gap:10px;
  }
  .resume-cert a{
    display:grid;
    grid-template-columns:40px 1fr;
    grid-template-rows:auto auto;
    column-gap:10px;
    row-gap:2px;
    padding:10px 12px;
    border-radius:14px;
    border:1px solid color-mix(in srgb,var(--text-light) 10%, transparent);
    background:transparent;
    text-decoration:none;
    color:inherit;
    transition:transform .15s ease, border-color .15s ease;
  }
  .resume-cert a:hover{
    transform:translateY(-1px);
    border-color:color-mix(in srgb,var(--primary) 32%, transparent);
  }
	  .resume-cert img{
	    grid-row:1 / span 2;
	    box-sizing:border-box;
	    width:40px;
	    height:40px;
	    padding:6px;
	    border-radius:12px;
	    object-fit:contain;
	    background:var(--logo-tile-bg-cert);
	    border:1px solid color-mix(in srgb,var(--primary) 10%, transparent);
	  }
  .resume-cert-title{
    font-weight:700;
    color:var(--text-light);
  }
  .resume-cert-meta{
    font-size:.88rem;
    color:var(--text-muted);
  }

  .resume-role{
    padding:0;
    border:none;
    border-radius:0;
    background:transparent;
  }
  .resume-role + .resume-role{
    margin-top:28px;
    padding-top:28px;
    border-top:1px solid color-mix(in srgb,var(--text-light) 10%, transparent);
  }
	  .resume-role-header{
	    display:grid;
	    grid-template-columns:minmax(0, 1fr) auto;
	    column-gap:16px;
	    row-gap:14px;
	    align-items:start;
	  }
	  .resume-role-brand{
	    display:flex;
	    gap:12px;
	    align-items:flex-start;
	    min-width:0;
	    text-decoration:none;
	    color:inherit;
	  }
	  a.resume-role-brand:hover .resume-role-logo-shell{
	    border-color:color-mix(in srgb,var(--primary) 32%, transparent);
	  }
	  .resume-role-brand > div{
	    min-width:0;
	  }
		  .resume-role-logo-shell{
		    height:56px;
		    min-width:56px;
		    padding:0 12px;
		    border-radius:16px;
		    background:var(--logo-tile-bg-company);
		    border:1px solid color-mix(in srgb,var(--primary) 12%, transparent);
		    display:inline-flex;
		    align-items:center;
		    justify-content:center;
		    box-sizing:border-box;
		    flex-shrink:0;
		  }
	  .resume-role-logo-shell img{
	    width:auto;
	    height:auto;
	    max-height:40px;
	    max-width:200px;
	    display:block;
	  }
  .resume-role-title{
    margin:0;
    font-size:1.24rem;
    color:var(--text-light);
  }
  .resume-role-company{
    margin:6px 0 0;
    color:color-mix(in srgb,var(--text-muted) 82%, #ffffff 18%);
    font-size:1.08rem;
  }
	  .resume-role-dates{
	    margin:0;
	    font-size:1.04rem;
	    color:var(--text-muted);
	    text-align:right;
	  }
  .resume-role-list{
    margin:18px 0 0 22px;
    display:grid;
    gap:10px;
    font-size:1.05rem;
    line-height:1.7;
    color:color-mix(in srgb,var(--text-muted) 80%, #ffffff 20%);
  }
  .resume-education-list{
    list-style:none;
    padding:0;
    margin:0;
    display:grid;
    gap:12px;
  }
	  .resume-education-item{
	    display:flex;
	    flex-wrap:wrap;
	    justify-content:space-between;
	    gap:10px 16px;
	    padding:14px 16px;
	    border-radius:12px;
	    border:1px solid color-mix(in srgb,var(--text-light) 10%, transparent);
	    background:transparent;
	    text-decoration:none;
	    color:inherit;
	    transition:transform .15s ease, border-color .15s ease;
	  }
	  a.resume-education-item:hover{
	    transform:translateY(-1px);
	    border-color:color-mix(in srgb,var(--primary) 32%, transparent);
	  }
  .resume-education-row{
    display:flex;
    gap:10px;
    align-items:flex-start;
  }
	  .resume-school-logo{
	    box-sizing:border-box;
	    width:40px;
	    height:40px;
	    padding:6px;
	    border-radius:12px;
	    object-fit:contain;
	    background:var(--logo-tile-bg-education);
	    border:1px solid color-mix(in srgb,var(--primary) 10%, transparent);
	    flex-shrink:0;
	  }
  .resume-education-title{
    margin:0;
    font-weight:600;
    color:var(--text-light);
    font-size:1rem;
  }
	  .resume-education-meta{
	    margin:4px 0 0;
	    color:var(--text-muted);
	    font-size:.95rem;
	  }
	  .resume-education-item > .resume-education-meta{
	    margin-left:auto;
	    text-align:right;
	  }

  .resume-projects-grid{
    list-style:none;
    padding:0;
    margin:0;
    display:grid;
    gap:12px;
    grid-template-columns:repeat(2, minmax(0, 1fr));
  }
  .resume-project{
    padding:12px 14px;
    border-radius:14px;
    border:1px solid color-mix(in srgb,var(--text-light) 10%, transparent);
    background:transparent;
    display:grid;
    gap:8px;
  }
  .resume-project-title{
    font-weight:700;
    color:var(--text-light);
    text-decoration:none;
    border-bottom:1px dashed color-mix(in srgb,var(--primary) 35%, transparent);
    width:fit-content;
  }
  .resume-project-title:hover{
    border-color:var(--primary);
  }
  .resume-project-meta{
    margin:0;
    color:var(--text-muted);
    line-height:1.55;
    font-size:.95rem;
  }
  .resume-more{
    margin:10px 0 0;
    color:var(--text-muted);
    font-size:.95rem;
  }
  .resume-more a{
    color:color-mix(in srgb,var(--primary) 80%, #ffffff 20%);
    text-decoration:none;
    border-bottom:1px dashed color-mix(in srgb,var(--primary) 40%, transparent);
  }
  .resume-more a:hover{
    border-color:var(--primary);
  }

  .resume-pdf{
    margin-top:16px;
    border-radius:16px;
    overflow:hidden;
    border:1px solid color-mix(in srgb,var(--primary) 25%, transparent);
    box-shadow:0 18px 38px rgba(0,0,0,.3);
  }
  .resume-pdf object{
    width:100%;
    height:clamp(480px, 70vh, 900px);
    display:block;
    background:var(--surface);
  }
  .resume-pdf-note{
    color:var(--text-muted);
    margin:0;
  }
  @media (max-width: 960px){
    .resume-body{
      grid-template-columns:1fr;
    }
    .resume-main{
      padding-left:0;
      border-left:none;
    }
    .resume-highlights{
      grid-template-columns:1fr;
    }
    .resume-projects-grid{
      grid-template-columns:1fr;
    }
  }
  @media (min-width: 980px){
    .resume-chip-list{
      grid-template-columns:repeat(2, minmax(0, 1fr));
      gap:10px;
    }
  }
	  @media (max-width: 720px){
	    .resume-role-header{
	      grid-template-columns:1fr;
	      align-items:start;
	    }
	    .resume-role-dates{
	      text-align:left;
	    }
	    .resume-education-item{
	      flex-direction:column;
	      align-items:flex-start;
	    }
	  }
  @media print{
    body{
      background:#fff;
      color:#000;
    }
    header,
    footer{
      display:none;
    }
    .resume-section{
      padding:0;
    }
    .resume-paper{
      box-shadow:none;
      border:1px solid #ccc;
      background:#fff;
      border-radius:0;
    }
    .resume-body{
      grid-template-columns:1fr;
    }
    .resume-main{
      padding-left:0;
      border-left:none;
    }
    .resume-actions{
      display:none;
    }
    .resume-contact-item,
    .resume-cert a,
    .resume-project{
      border:1px solid #ddd;
      background:transparent;
    }
    .resume-contact-item,
    .resume-highlight-label,
    .resume-education-meta,
    .resume-project-meta,
    .resume-more{
      color:#333;
    }
    .resume-name,
    .resume-role-title,
    .resume-block-title{
      color:#000;
    }
    .resume-project-title,
    .resume-more a{
      color:#000;
      border-color:#000;
    }
  }
}
