/* =========================================================
   Vincenzo Accardi — personal site
   Theme: "Waybill" — a manifest / shipping-label aesthetic,
   grounded in a career spent moving things (and code)
   from one place to another.
   ========================================================= */

@import url('https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@500;700&family=Inter:wght@400;500;600&family=IBM+Plex+Mono:wght@400;500&display=swap');

:root{
  /* surfaces */
  --ink:        #1B231F;
  --ink-raised: #232E29;
  --ink-line:   rgba(237,231,216,0.12);

  /* paper (labels, cards, stamps) */
  --paper:      #F2ECDC;
  --paper-dim:  #E4DCC8;
  --paper-line: rgba(27,35,31,0.14);

  /* text */
  --text:       #EDE7D8;
  --text-muted: #93A39A;
  --text-ink:   #1F2722;
  --text-ink-muted: #5C6960;

  /* accents */
  --accent:   #D9643A; /* stamp red-orange */
  --accent-2: #7FAE8E; /* sage postal green */
  --gold:     #E3BB55; /* stamp gold */

  /* type */
  --f-display: 'Space Grotesk', sans-serif;
  --f-body: 'Inter', sans-serif;
  --f-mono: 'IBM Plex Mono', monospace;

  --container: 1080px;
}

*{ box-sizing: border-box; }
html{ scroll-behavior: smooth; }

body{
  margin:0;
  background: var(--ink);
  color: var(--text);
  font-family: var(--f-body);
  font-size: 16px;
  line-height: 1.65;
  -webkit-font-smoothing: antialiased;
}

img{ max-width:100%; display:block; }

a{ color: var(--accent-2); text-decoration:none; }
a:hover{ color: var(--gold); }

:focus-visible{
  outline: 2px solid var(--gold);
  outline-offset: 3px;
  border-radius: 2px;
}

.wrap{
  max-width: var(--container);
  margin: 0 auto;
  padding: 0 28px;
}

/* =========================================================
   Texture — faint diagonal "carbon copy" lines on dark bg
   ========================================================= */
body{
  background-image:
    repeating-linear-gradient(135deg, rgba(255,255,255,0.012) 0px, rgba(255,255,255,0.012) 1px, transparent 1px, transparent 64px);
}

/* =========================================================
   HEADER / HERO
   ========================================================= */
.hero{
  padding: 64px 0 56px;
}

.hero-label{
  background: var(--paper);
  color: var(--text-ink);
  border-radius: 6px;
  padding: 36px 36px 28px;
  position: relative;
  box-shadow: 0 18px 50px -24px rgba(0,0,0,0.6);
}

.hero-label::before{
  /* perforation strip along the top */
  content:"";
  position:absolute;
  top:0; left:24px; right:24px; height:0;
  border-top: 2px dashed var(--paper-line);
}

.hero-top{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap: 24px;
  flex-wrap: wrap;
}

.hero-id{
  display:flex;
  align-items:center;
  gap: 18px;
}

.stamp{
  flex: none;
  width: 64px;
  height: 64px;
  border-radius: 50%;
  border: 2px solid var(--accent);
  display:flex;
  align-items:center;
  justify-content:center;
  font-family: var(--f-display);
  font-weight: 700;
  font-size: 1.1rem;
  letter-spacing: 0.04em;
  color: var(--accent);
  transform: rotate(-8deg);
  position: relative;
}
.stamp::after{
  content:"";
  position:absolute;
  inset: 6px;
  border-radius: 50%;
  border: 1px dotted var(--accent);
  opacity:.6;
}

.hero h1{
  margin: 0 0 4px;
  font-family: var(--f-display);
  font-weight: 700;
  font-size: clamp(1.9rem, 4vw, 2.6rem);
  letter-spacing: -0.01em;
}

.hero .role{
  margin:0;
  font-family: var(--f-mono);
  font-size: 0.92rem;
  letter-spacing: 0.04em;
  color: var(--text-ink-muted);
  text-transform: uppercase;
}

.hero-ref{
  font-family: var(--f-mono);
  font-size: 0.78rem;
  color: var(--text-ink-muted);
  letter-spacing: 0.08em;
  text-align: right;
  white-space: nowrap;
  padding-top: 6px;
}
.hero-ref strong{
  display:block;
  font-size: 0.95rem;
  color: var(--text-ink);
  letter-spacing: 0.12em;
}

/* route line: PALERMO ........ MODENA */
.route{
  margin-top: 28px;
  display:flex;
  align-items:center;
  gap: 14px;
  font-family: var(--f-mono);
  font-size: 0.78rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--text-ink-muted);
}
.route .pt{
  display:flex;
  align-items:center;
  gap:8px;
  color: var(--text-ink);
  white-space: nowrap;
}
.route .pt::before{
  content:"";
  width:9px; height:9px;
  border-radius:50%;
  border: 2px solid var(--accent);
  background: var(--paper);
  flex: none;
}
.route .line{
  flex:1;
  height:0;
  border-top: 1px dotted var(--text-ink-muted);
  min-width: 30px;
}

/* hero actions */
.hero-actions{
  margin-top: 28px;
  display:flex;
  flex-wrap: wrap;
  gap: 12px;
  align-items:center;
}

.btn{
  display:inline-flex;
  align-items:center;
  gap: 8px;
  font-family: var(--f-mono);
  font-size: 0.82rem;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  padding: 11px 20px;
  border-radius: 4px;
  border: 1px solid transparent;
  cursor:pointer;
  transition: transform .15s ease, background .2s ease, color .2s ease, border-color .2s ease;
}
.btn-primary{
  background: var(--accent);
  color: var(--paper);
}
.btn-primary:hover{
  background: #c4582f;
  color: var(--paper);
  transform: translateY(-1px);
}
.btn-ghost{
  background: transparent;
  border-color: var(--paper-line);
  color: var(--text-ink);
}
.btn-ghost:hover{
  border-color: var(--accent);
  color: var(--accent);
  transform: translateY(-1px);
}

.social-row{
  display:flex;
  gap: 6px;
  margin-left: auto;
}
.social-row a{
  width: 38px; height: 38px;
  border-radius: 50%;
  display:flex; align-items:center; justify-content:center;
  border: 1px solid var(--paper-line);
  color: var(--text-ink-muted);
  font-size: 1rem;
  transition: all .2s ease;
}
.social-row a:hover{
  border-color: var(--accent-2);
  color: var(--accent-2);
  transform: translateY(-2px);
}

/* =========================================================
   SECTIONS / MANIFEST ENTRIES
   ========================================================= */
.entry{
  padding: 56px 0;
  border-top: 1px solid var(--ink-line);
}

.entry-head{
  display:flex;
  align-items:baseline;
  justify-content:space-between;
  gap: 16px;
  margin-bottom: 28px;
  flex-wrap: wrap;
}

.entry-label{
  font-family: var(--f-mono);
  font-size: 0.75rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--text-muted);
}

.entry-head h2{
  margin: 4px 0 0;
  font-family: var(--f-display);
  font-weight: 700;
  font-size: clamp(1.4rem, 3vw, 1.9rem);
}

.entry-count{
  font-family: var(--f-mono);
  font-size: 0.75rem;
  letter-spacing: 0.18em;
  color: var(--text-muted);
  white-space: nowrap;
}

/* About */
.about-grid{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 36px;
}
.about-grid p{
  margin: 0 0 1.1em;
  color: var(--text);
}
.about-grid p:last-child{ margin-bottom:0; }

@media (max-width: 760px){
  .about-grid{ grid-template-columns: 1fr; gap: 0; }
}

/* =========================================================
   PORTFOLIO — shipping-label cards (signature element)
   ========================================================= */
.portfolio-grid{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 22px;
}
@media (max-width: 900px){
  .portfolio-grid{ grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 620px){
  .portfolio-grid{ grid-template-columns: 1fr; }
}

.label-card{
  background: var(--paper);
  color: var(--text-ink);
  border-radius: 6px;
  padding: 20px 20px 18px;
  display:flex;
  flex-direction: column;
  position: relative;
  transition: transform .25s ease, box-shadow .25s ease;
}
.label-card::before{
  content:"";
  position:absolute;
  top:0; left:18px; right:18px; height:0;
  border-top: 2px dashed var(--paper-line);
}
.label-card:hover{
  transform: translateY(-4px) rotate(-0.4deg);
  box-shadow: 0 16px 36px -20px rgba(0,0,0,0.55);
}

.label-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  font-family: var(--f-mono);
  font-size: 0.72rem;
  letter-spacing: 0.12em;
  color: var(--text-ink-muted);
  text-transform: uppercase;
  margin-bottom: 14px;
}
.label-head .code{ color: var(--accent); font-weight:500; }
.label-head .barcode{
  display:flex;
  gap: 2px;
  align-items:flex-end;
  height: 14px;
}
.label-head .barcode span{
  display:block;
  width: 2px;
  background: var(--text-ink-muted);
  opacity:.55;
}

.label-card h3{
  margin: 0 0 8px;
  font-family: var(--f-display);
  font-weight: 700;
  font-size: 1.15rem;
  line-height: 1.3;
}
.label-card h3 a{ color: var(--text-ink); }
.label-card h3 a:hover{ color: var(--accent); }

.label-card p{
  margin: 0 0 18px;
  font-size: 0.92rem;
  color: var(--text-ink-muted);
  flex: 1;
}

.label-link{
  font-family: var(--f-mono);
  font-size: 0.78rem;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--accent);
  display:inline-flex;
  align-items:center;
  gap:6px;
}
.label-link:hover{ color: var(--accent-2); }
.label-link::after{ content:"→"; transition: transform .2s ease; }
.label-card:hover .label-link::after{ transform: translateX(3px); }

.empty-note{
  font-family: var(--f-mono);
  font-size: 0.85rem;
  color: var(--text-muted);
  border: 1px dashed var(--ink-line);
  border-radius: 6px;
  padding: 28px;
  text-align:center;
}

/* =========================================================
   EXPERIENCE — manifest line items
   ========================================================= */
.timeline{
  display:flex;
  flex-direction: column;
}
.timeline-item{
  display:grid;
  grid-template-columns: 150px 1fr;
  gap: 24px;
  padding: 20px 0;
  border-top: 1px solid var(--ink-line);
}
.timeline-item:first-child{ border-top:0; padding-top:0; }

.timeline-date{
  font-family: var(--f-mono);
  font-size: 0.8rem;
  color: var(--accent-2);
  letter-spacing: 0.04em;
  padding-top: 3px;
}

.timeline-body h3{
  margin: 0 0 4px;
  font-family: var(--f-display);
  font-size: 1.05rem;
  font-weight: 700;
}
.timeline-body h3 .place{
  font-weight: 500;
  color: var(--text-muted);
}
.timeline-body h3 .place a{ color: var(--text-muted); }
.timeline-body h3 .place a:hover{ color: var(--accent-2); }

.timeline-body p{
  margin: 6px 0 0;
  color: var(--text-muted);
  font-size: 0.94rem;
}

@media (max-width: 620px){
  .timeline-item{ grid-template-columns: 1fr; gap: 6px; }
}

/* =========================================================
   SKILLS — stamp chips
   ========================================================= */
.skills-groups{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 28px;
}
@media (max-width: 760px){
  .skills-groups{ grid-template-columns: 1fr 1fr; }
}
@media (max-width: 480px){
  .skills-groups{ grid-template-columns: 1fr; }
}

.skill-group h3{
  font-family: var(--f-mono);
  font-size: 0.72rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--text-muted);
  margin: 0 0 12px;
}

.chip-row{
  display:flex;
  flex-wrap: wrap;
  gap: 8px;
}
.chip{
  font-family: var(--f-mono);
  font-size: 0.78rem;
  letter-spacing: 0.02em;
  color: var(--text);
  border: 1px solid var(--ink-line);
  border-radius: 4px;
  padding: 6px 11px;
}

/* =========================================================
   CONTACT strip
   ========================================================= */
.contact-strip{
  display:flex;
  flex-wrap: wrap;
  gap: 14px 36px;
  align-items:center;
  justify-content: space-between;
}
.contact-strip .item{
  display:flex;
  align-items:center;
  gap: 10px;
  font-family: var(--f-mono);
  font-size: 0.9rem;
  color: var(--text);
}
.contact-strip .item i{
  color: var(--accent-2);
  width: 18px;
  text-align:center;
}
.contact-strip a{ color: var(--text); }
.contact-strip a:hover{ color: var(--gold); }

/* =========================================================
   FOOTER
   ========================================================= */
.footer{
  border-top: 1px solid var(--ink-line);
  padding: 28px 0 40px;
  font-family: var(--f-mono);
  font-size: 0.78rem;
  color: var(--text-muted);
  letter-spacing: 0.04em;
  display:flex;
  flex-wrap:wrap;
  justify-content: space-between;
  gap: 10px;
}
.footer a{ color: var(--text-muted); }
.footer a:hover{ color: var(--gold); }

/* =========================================================
   Reduced motion
   ========================================================= */
@media (prefers-reduced-motion: reduce){
  *{ transition: none !important; animation: none !important; }
  html{ scroll-behavior: auto; }
}

/* =========================================================
   ADMIN PANEL
   ========================================================= */
.admin-body{
  background: var(--paper-dim);
  color: var(--text-ink);
  min-height: 100vh;
}
.admin-shell{
  max-width: 760px;
  margin: 0 auto;
  padding: 48px 24px 80px;
}
.admin-header{
  display:flex;
  align-items:center;
  justify-content: space-between;
  margin-bottom: 32px;
  flex-wrap: wrap;
  gap: 12px;
}
.admin-header h1{
  font-family: var(--f-display);
  font-size: 1.5rem;
  margin:0;
}
.admin-header .tag{
  font-family: var(--f-mono);
  font-size: 0.75rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--text-ink-muted);
}

.panel{
  background: var(--paper);
  border-radius: 6px;
  padding: 28px;
  margin-bottom: 24px;
  box-shadow: 0 1px 0 var(--paper-line);
}
.panel h2{
  margin: 0 0 18px;
  font-family: var(--f-display);
  font-size: 1.05rem;
}

.field{
  margin-bottom: 16px;
}
.field label{
  display:block;
  font-family: var(--f-mono);
  font-size: 0.75rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--text-ink-muted);
  margin-bottom: 6px;
}
.field input[type=text],
.field input[type=url],
.field input[type=password],
.field textarea{
  width: 100%;
  font-family: var(--f-body);
  font-size: 0.95rem;
  padding: 11px 13px;
  border: 1px solid var(--paper-line);
  border-radius: 4px;
  background: #fff;
  color: var(--text-ink);
}
.field input:focus, .field textarea:focus{
  outline: 2px solid var(--accent-2);
  outline-offset: 1px;
  border-color: var(--accent-2);
}
.field textarea{ min-height: 90px; resize: vertical; }
.field .hint{
  font-size: 0.8rem;
  color: var(--text-ink-muted);
  margin-top: 4px;
}

.admin-actions{
  display:flex;
  gap: 10px;
  flex-wrap: wrap;
}

.btn-dark{
  background: var(--ink);
  color: var(--paper);
}
.btn-dark:hover{ background:#2a3530; color: var(--paper); }

.btn-outline{
  background: transparent;
  border: 1px solid var(--paper-line);
  color: var(--text-ink);
}
.btn-outline:hover{ border-color: var(--accent); color: var(--accent); }

.btn-danger{
  background: transparent;
  border: 1px solid rgba(217,100,58,0.4);
  color: var(--accent);
}
.btn-danger:hover{ background: var(--accent); color: var(--paper); }

.btn-small{
  padding: 7px 13px;
  font-size: 0.72rem;
}

.list-item{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap: 16px;
  padding: 16px 0;
  border-top: 1px solid var(--paper-line);
}
.list-item:first-child{ border-top:0; padding-top:0; }
.list-item .meta{ flex:1; min-width:0; }
.list-item .code{
  font-family: var(--f-mono);
  font-size: 0.7rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--accent);
  display:block;
  margin-bottom: 4px;
}
.list-item h3{
  margin: 0 0 4px;
  font-family: var(--f-display);
  font-size: 1.02rem;
}
.list-item p{
  margin: 0;
  font-size: 0.88rem;
  color: var(--text-ink-muted);
  word-break: break-word;
}
.list-item .ops{
  display:flex;
  flex-direction:column;
  gap: 6px;
  flex: none;
}
.list-item form{ margin:0; }

.flash{
  font-family: var(--f-mono);
  font-size: 0.85rem;
  border-radius: 4px;
  padding: 12px 16px;
  margin-bottom: 20px;
  letter-spacing: 0.02em;
}
.flash-ok{ background: rgba(127,174,142,0.18); color: #355a44; }
.flash-err{ background: rgba(217,100,58,0.16); color: #a3431f; }

.login-shell{
  max-width: 380px;
  margin: 14vh auto 0;
  padding: 0 24px;
}
.login-shell .panel{ text-align:left; }
.login-shell h1{
  font-family: var(--f-display);
  font-size: 1.3rem;
  margin: 0 0 4px;
}
.login-shell .sub{
  font-family: var(--f-mono);
  font-size: 0.78rem;
  color: var(--text-ink-muted);
  margin: 0 0 24px;
  letter-spacing: 0.05em;
}
