body.public-roles .public-roles{
  position:relative;
  isolation:isolate;
  display:grid;
  gap:22px;
}

body.public-roles .public-roles::before{
  content:"";
  position:absolute;
  inset:-14px 0 auto;
  height:210px;
  background:linear-gradient(180deg, rgba(15,118,110,.05), transparent 72%);
  pointer-events:none;
  z-index:0;
}

body.public-roles .public-roles > *{
  position:relative;
  z-index:1;
}

body.public-roles .public-roles__hero{
  display:grid;
  grid-template-columns:minmax(0,.94fr) minmax(0,1.06fr);
  gap:18px;
  align-items:stretch;
  padding:14px 0 2px;
  animation:public-fade-up .72s cubic-bezier(.2,.8,.2,1) both;
}

body.public-roles .public-roles__copy{
  display:grid;
  gap:12px;
  align-content:center;
}

body.public-roles .public-roles__copy h1{
  max-width:20ch;
  margin:0;
  color:#0f172a;
  font-size:clamp(1.9rem, 3.3vw, 3.3rem);
  line-height:1.02;
  letter-spacing:-.055em;
}

body.public-roles .public-roles__copy p{
  max-width:56ch;
  margin:0;
  color:#475569;
  line-height:1.66;
  font-size:.96rem;
}

body.public-roles .public-roles__meta{
  display:inline-flex;
  align-items:center;
  gap:10px;
  width:fit-content;
  max-width:100%;
  margin-top:4px;
  padding:10px 14px;
  border-radius:999px;
  border:1px solid rgba(15,23,42,.08);
  background:rgba(255,255,255,.90);
  color:#475569;
  box-shadow:0 10px 22px rgba(15,23,42,.04);
  animation:public-fade-up .72s cubic-bezier(.2,.8,.2,1) both .06s;
}

body.public-roles .public-roles__meta::before{
  content:"";
  width:8px;
  height:8px;
  flex:none;
  border-radius:999px;
  background:#0f766e;
  box-shadow:0 0 0 6px rgba(15,118,110,.08);
}

body.public-roles .public-roles__visual{
  position:relative;
  display:grid;
  gap:10px;
  padding:14px;
  border-radius:26px;
  border:1px solid rgba(15,23,42,.08);
  background:
    radial-gradient(circle at top right, rgba(15,118,110,.08), transparent 28%),
    linear-gradient(180deg, #fff 0%, #f8fafc 100%);
  box-shadow:0 18px 36px rgba(15,23,42,.06);
  animation:public-fade-up .82s cubic-bezier(.2,.8,.2,1) both .08s;
}

body.public-roles .public-roles__visual img{
  display:block;
  width:100%;
  min-height:182px;
  object-fit:cover;
  object-position:center;
  border-radius:22px;
}

body.public-roles .public-roles__visual-card{
  display:grid;
  gap:5px;
  padding:12px 14px;
  border-radius:18px;
  background:#0f172a;
  color:#fff;
  box-shadow:0 14px 26px rgba(15,23,42,.14);
}

body.public-roles .public-roles__visual-card span{
  color:rgba(255,255,255,.7);
  font-size:.74rem;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.14em;
}

body.public-roles .public-roles__visual-card strong{
  color:#fff;
  line-height:1.48;
  font-size:.95rem;
}

body.public-roles .public-roles__grid{
  position:relative;
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(220px,1fr));
  gap:12px;
  animation:public-fade-up .86s cubic-bezier(.2,.8,.2,1) both .16s;
}

body.public-roles .public-role-card{
  --role-accent:#1d4ed8;
  position:relative;
  overflow:hidden;
  display:grid;
  gap:10px;
  padding:16px;
  border-radius:22px;
  border:1px solid rgba(15,23,42,.08);
  background:#fff;
  box-shadow:0 12px 24px rgba(15,23,42,.05);
  transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease;
  animation:public-fade-up .74s cubic-bezier(.2,.8,.2,1) both;
}

body.public-roles .public-role-card:nth-child(2){ animation-delay:.06s; }
body.public-roles .public-role-card:nth-child(3){ animation-delay:.12s; }
body.public-roles .public-role-card:nth-child(4){ animation-delay:.18s; }

body.public-roles .public-role-card::before{
  content:"";
  position:absolute;
  inset:0 auto auto 0;
  width:100%;
  height:3px;
  background:var(--role-accent);
  opacity:.72;
}

body.public-roles .public-role-card span{
  display:inline-flex;
  width:fit-content;
  padding:7px 11px;
  border-radius:999px;
  background:rgba(29,78,216,.10);
  color:#1d4ed8;
  font-size:.72rem;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.14em;
}

body.public-roles .public-role-card h3{
  margin:0;
  color:#0f172a;
  font-size:1rem;
}

body.public-roles .public-role-card p{
  margin:0;
  color:#475569;
  line-height:1.62;
  font-size:.95rem;
}

body.public-roles .public-role-card:hover{
  transform:translateY(-2px);
  border-color:rgba(15,23,42,.14);
  box-shadow:0 18px 30px rgba(15,23,42,.08);
}

body.public-roles .public-role-card--manager{ --role-accent:#0f172a; }
body.public-roles .public-role-card--branch{ --role-accent:#0f766e; }
body.public-roles .public-role-card--team{ --role-accent:#7c3aed; }
body.public-roles .public-role-card--student{ --role-accent:#b45309; }

body.public-roles .public-role-card--manager span{ background:rgba(15,23,42,.10); color:#0f172a; }
body.public-roles .public-role-card--branch span{ background:rgba(15,118,110,.10); color:#0f766e; }
body.public-roles .public-role-card--team span{ background:rgba(124,58,237,.10); color:#7c3aed; }
body.public-roles .public-role-card--student span{ background:rgba(180,83,9,.10); color:#b45309; }

@media (max-width: 1100px){
  body.public-roles .public-roles__hero,
  body.public-roles .public-roles__grid{
    grid-template-columns:1fr;
  }

  body.public-roles .public-roles__visual img{
    min-height:164px;
  }
}

@media (max-width: 700px){
  body.public-roles .public-roles__copy h1{
    max-width:none;
    font-size:clamp(2rem, 9vw, 3rem);
  }

  body.public-roles .public-role-card{
    padding:16px;
  }

  body.public-roles .public-roles__meta{
    width:100%;
    padding:10px 13px;
    border-radius:18px;
  }
}

@media (min-width: 1101px) and (max-height: 900px){
  body.public-roles .public-roles__hero{
    padding:10px 0 0;
  }

  body.public-roles .public-roles__copy{
    gap:8px;
  }

  body.public-roles .public-roles__copy h1{
    font-size:clamp(1.9rem, 3.3vw, 3.2rem);
  }

  body.public-roles .public-roles__visual img{
    min-height:160px;
  }

  body.public-roles .public-roles__grid{
    gap:10px;
  }

  body.public-roles .public-role-card{
    padding:14px;
  }
}

body.public-glass.public-roles .public-roles__copy h1,
body.public-glass.public-roles .public-role-card h3,
body.public-glass.public-roles .public-roles__visual-card strong{
  color:#0f172a;
}

body.public-glass.public-roles .public-roles__copy p,
body.public-glass.public-roles .public-role-card p{
  color:#475569;
}

body.public-glass.public-roles .public-roles__meta,
body.public-glass.public-roles .public-roles__visual,
body.public-glass.public-roles .public-role-card,
body.public-glass.public-roles .public-roles__visual-card{
  background:rgba(255,255,255,.68);
  border:1px solid rgba(255,255,255,.58);
  box-shadow:0 18px 40px rgba(15,23,42,.08);
  backdrop-filter:blur(18px) saturate(155%);
}

body.public-glass.public-roles .public-roles__visual-card{
  color:#0f172a;
}

body.public-glass.public-roles .public-role-card::before{
  opacity:.88;
}

body.public-glass.public-roles .public-role-card span{
  color:#fff;
}

@media (max-width: 1100px){
  body.public-glass.public-roles .public-roles__hero,
  body.public-glass.public-roles .public-roles__grid{
    grid-template-columns:1fr;
  }
}

@keyframes public-fade-up{
  from{
    opacity:0;
    transform:translateY(16px);
  }
  to{
    opacity:1;
    transform:translateY(0);
  }
}
