.notice-page{background:#f7faff}
.notice-page-header{padding-bottom:2.3rem}
.notice-tab-wrap{background:#fff;border-bottom:1px solid var(--border)}
.notice-tabs{display:flex;align-items:center;gap:0}
.notice-tabs a{display:flex;align-items:center;gap:.45rem;padding:1.05rem 1.35rem;border-bottom:3px solid transparent;font-size:.92rem;font-weight:800;color:var(--text2);text-decoration:none}
.notice-tabs a:hover,.notice-tabs a.active{color:var(--blue)}
.notice-tabs a.active{border-bottom-color:var(--blue)}
.notice-tabs span{min-width:24px;padding:.12rem .45rem;border-radius:999px;background:var(--sky);color:var(--blue);font-size:.7rem;text-align:center}
.notice-tabs a.active span{background:var(--blue);color:#fff}
.notice-section{padding-top:1.8rem;padding-bottom:4rem}
.pinned-notice{display:flex;align-items:center;gap:1rem;margin-bottom:.75rem;padding:1.2rem 1.35rem;border:1px solid rgba(27,142,240,.28);border-radius:16px;background:linear-gradient(120deg,#e8f4ff 0%,#ebf9f5 100%);color:inherit;text-decoration:none}
.pinned-notice:hover{box-shadow:0 10px 28px rgba(27,142,240,.12)}
.pin-badge{flex-shrink:0;padding:.24rem .62rem;border-radius:8px;background:var(--blue);color:#fff;font-size:.72rem;font-weight:800}
.pin-title{flex:1;min-width:0;font-size:.96rem;font-weight:800;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.pin-date{flex-shrink:0;font-size:.78rem;color:var(--text2)}
.notice-list{margin-top:1rem;overflow:hidden;border:1px solid var(--border);border-radius:16px;background:#fff}
.notice-item{display:grid;grid-template-columns:48px minmax(0,1fr) 92px;align-items:center;gap:1rem;padding:1.05rem 1.35rem;border-bottom:1px solid var(--border);color:inherit;text-decoration:none}
.notice-item:last-child{border-bottom:0}
.notice-item:hover{background:#f9fcff}
.notice-num{font-family:Nunito,sans-serif;font-size:.84rem;font-weight:900;color:#8792a4;text-align:center}
.notice-title-wrap{display:flex;align-items:center;gap:.55rem;min-width:0}
.notice-badge{flex-shrink:0;padding:.19rem .52rem;border-radius:6px;font-size:.68rem;font-weight:900}
.badge-notice{background:#e8f4ff;color:#1b8ef0}
.badge-event{background:#fff0eb;color:#ff6b4a}
.badge-update{background:#e6fbf5;color:#00a383}
.notice-title{min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-size:.92rem;font-weight:700;color:var(--text)}
.notice-new{flex-shrink:0;padding:.1rem .35rem;border-radius:5px;background:#fff0eb;color:#ff6b4a;font-size:.62rem;font-weight:900}
.notice-right{display:flex;flex-direction:column;align-items:flex-end;gap:.15rem;font-size:.74rem;color:var(--text2)}
.notice-views{font-size:.7rem;color:#8a95a6}
.notice-empty,.notice-detail-empty{margin:3rem auto;padding:3rem 1.5rem;max-width:720px;border:1px solid var(--border);border-radius:16px;background:#fff;text-align:center}
.notice-empty strong,.notice-detail-empty strong{display:block;margin-bottom:.45rem;font-size:1.05rem}
.notice-empty p,.notice-detail-empty p{color:var(--text2)}
.notice-detail-empty a{display:inline-flex;margin-top:1.2rem;padding:.75rem 1.35rem;border-radius:999px;background:var(--blue);color:#fff;text-decoration:none;font-weight:800}
.notice-pagination{display:flex;justify-content:center;gap:.45rem;margin-top:2rem}
.notice-pagination a{min-width:38px;height:38px;display:inline-flex;align-items:center;justify-content:center;border:1px solid var(--border);border-radius:999px;background:#fff;color:var(--text2);text-decoration:none;font-weight:800}
.notice-pagination a.active,.notice-pagination a:hover{background:var(--blue);border-color:var(--blue);color:#fff}
.event-banner{display:grid;grid-template-columns:minmax(0,1fr) 390px;margin-bottom:1.5rem;overflow:hidden;border-radius:18px;background:#172033;color:#fff;text-decoration:none}
.event-banner-body{padding:2.2rem 2.4rem}
.event-banner-eyebrow{display:flex;align-items:center;gap:.55rem;margin-bottom:.75rem}
.event-banner-eyebrow span,.event-status-badge{display:inline-flex;align-items:center;padding:.23rem .65rem;border-radius:999px;font-size:.72rem;font-weight:900}
.event-banner-eyebrow em{font-style:normal;color:rgba(255,255,255,.62);font-size:.78rem;font-weight:700}
.status-ongoing{background:#00c9a0;color:#fff}
.status-ended{background:rgba(17,24,39,.58);color:rgba(255,255,255,.85)}
.event-banner strong{display:block;margin-bottom:.55rem;font-size:1.55rem;line-height:1.28;font-weight:900}
.event-banner p{max-width:620px;margin-bottom:1rem;color:rgba(255,255,255,.72);line-height:1.7}
.event-banner small{color:rgba(255,255,255,.62);font-weight:700}
.event-banner-image{background:linear-gradient(135deg,rgba(27,142,240,.4),rgba(0,201,160,.35));background-size:cover;background-position:center}
.event-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:1.2rem}
.event-card{display:block;overflow:hidden;border:1px solid var(--border);border-radius:16px;background:#fff;color:inherit;text-decoration:none;transition:transform .18s,box-shadow .18s}
.event-card:hover{transform:translateY(-3px);box-shadow:0 14px 34px rgba(27,142,240,.11)}
.event-img{position:relative;display:block;aspect-ratio:3/4;background:linear-gradient(135deg,#e8f4ff,#ebf9f5);background-size:cover;background-position:center}
.event-status-badge{position:absolute;top:.75rem;left:.75rem}
.event-body{display:block;padding:1rem}
.event-body small{display:block;margin-bottom:.34rem;color:var(--blue);font-size:.72rem;font-weight:900}
.event-body strong{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;min-height:2.76em;margin-bottom:.5rem;font-size:.95rem;line-height:1.38}
.event-body span{display:block;margin-bottom:.55rem;color:var(--text2);font-size:.76rem;font-weight:700}
.event-body p{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;color:#697589;font-size:.78rem;line-height:1.6}
.notice-detail-head{display:flex;align-items:flex-end;min-height:340px;margin-top:94px;background:linear-gradient(135deg,#e8f4ff 0%,#ebf9f5 52%,#fff8ec 100%);padding:0 0 2.35rem}
.notice-detail-inner{max-width:920px}
.notice-detail-breadcrumb{display:flex;gap:.42rem;align-items:center;margin-bottom:1.25rem;color:var(--text2);font-size:.8rem}
.notice-detail-breadcrumb a{color:var(--text2);text-decoration:none}
.notice-detail-breadcrumb a:hover{color:var(--blue)}
.notice-detail-label{display:inline-flex;align-items:center;padding:.25rem .7rem;margin-bottom:.85rem;border-radius:999px;background:var(--blue);color:#fff;font-size:.74rem;font-weight:900}
.event-detail-head .notice-detail-label.status-ended{background:#4b5563}
.notice-detail-head h1{max-width:900px;margin:0 0 .75rem;font-family:'Noto Serif KR','Noto Sans KR',serif;font-size:2.8rem;font-weight:600;line-height:1.25;letter-spacing:0}
.notice-detail-head p{max-width:760px;color:var(--text2);font-size:1rem;line-height:1.75}
.notice-detail-meta{display:flex;align-items:center;gap:.55rem;margin-top:1.1rem;color:#687386;font-size:.82rem;font-weight:700}
.notice-detail-meta i{width:3px;height:3px;border-radius:50%;background:#b7c1d0}
.notice-detail-article{max-width:920px;margin-top:2rem;margin-bottom:2rem;padding:2.2rem;border:1px solid var(--border);border-radius:18px;background:#fff}
.notice-detail-image{display:block;width:100%;max-height:520px;object-fit:cover;margin-bottom:2rem;border-radius:14px}
.notice-detail-body{font-size:1rem;line-height:1.9;color:var(--text)}
.notice-detail-body img{max-width:100%;height:auto;border-radius:12px}
.notice-detail-body a{color:var(--blue);text-decoration:underline;text-underline-offset:2px}
.notice-comments-wrap{width:min(920px,calc(100% - 2rem));max-width:920px;margin-left:auto;margin-right:auto;margin-bottom:2rem;padding-left:0;padding-right:0}
.notice-comments-wrap .post-comments{margin:0}
.notice-adjacent{width:min(920px,calc(100% - 2rem));max-width:920px;display:flex;flex-direction:column;gap:.7rem;margin-left:auto;margin-right:auto;padding-left:0;padding-right:0}
.notice-adjacent a{display:grid;grid-template-columns:86px minmax(0,1fr);align-items:center;gap:.9rem;padding:1rem 1.15rem;border:1px solid var(--border);border-radius:14px;background:#fff;color:inherit;text-decoration:none}
.notice-adjacent span{display:block;margin-bottom:0;color:var(--text2);font-size:.76rem;font-weight:800}
.notice-adjacent strong{display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-size:.92rem}
.notice-back-wrap{max-width:920px;margin-top:1.2rem;margin-bottom:4rem;text-align:center}
.notice-back{display:inline-flex;align-items:center;justify-content:center;padding:.78rem 1.8rem;border:2px solid var(--blue);border-radius:999px;background:#fff;color:var(--blue);text-decoration:none;font-weight:900}
.notice-back:hover{background:var(--blue);color:#fff}
@media(max-width:900px){
  .notice-tabs{overflow-x:auto}
  .event-banner{grid-template-columns:1fr}
  .event-banner-image{display:none}
  .event-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .notice-detail-head{min-height:300px;margin-top:60px}
  .notice-detail-head h1{font-size:2.15rem}
}
@media(max-width:640px){
  .notice-section{padding-top:1.25rem}
  .notice-tabs a{padding:.95rem 1rem}
  .pinned-notice{flex-wrap:wrap;gap:.55rem}
  .pin-title{flex-basis:100%;white-space:normal}
  .notice-item{grid-template-columns:minmax(0,1fr);gap:.45rem;padding:1rem}
  .notice-num{display:none}
  .notice-title-wrap{align-items:flex-start}
  .notice-title{white-space:normal;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}
  .notice-right{align-items:flex-start;flex-direction:row;gap:.6rem}
  .event-grid{grid-template-columns:1fr}
  .event-banner-body{padding:1.6rem}
  .notice-detail-head{min-height:240px;padding-bottom:1.45rem}
  .notice-detail-head h1{font-size:1.5rem}
  .notice-detail-article{padding:1.35rem;border-radius:14px}
  .notice-adjacent a{grid-template-columns:1fr;gap:.3rem}
}
