/* =========================================================
   theme/40 — 2026 사진·AI 이미지 공모전 (사진·AI 이미지 공모전 원본 개별 흡수)
   브랜드색은 index head @theme 토큰(--color-ink/accent/...)으로 등록 → bg-ink/80 등 불투명도 변형 사용.
   본 파일은 컨테이너·full-bleed·grid 보정·동적 컴포넌트 보조 스타일만.
   ========================================================= */

:root{
  --ink:#0d1b2a; --ink2:#13243a; --accent:#e63946; --accent2:#ff5a67;
  --line:#eef0f3; --soft:#f9fafb;
}

/* 공통 컨테이너 (원본 max-width ≈ 1200px) */
.theme-area{ width:100%; max-width:75rem; margin-inline:auto; padding-inline:1.25rem; }
@media (min-width:768px){ .theme-area{ padding-inline:2rem; } }

/* grid 자식 overflow 방지(플레이북 표준) */
[class*="grid-cols"] > *{ min-width:0; }

img{ max-width:100%; }

/* ====== HERO ====== */
.hero{ background:var(--ink); }
.hero-bg{
  position:absolute; inset:0;
  background:url("https://picsum.photos/seed/contesthero/1600/900") center/cover no-repeat;
  opacity:.5;
}
.hero-overlay{
  position:absolute; inset:0;
  background:linear-gradient(105deg, rgba(13,27,42,.96) 0%, rgba(13,27,42,.78) 45%, rgba(13,27,42,.55) 100%);
}

/* 카운트다운 카드 */
.countdown-card{
  border-radius:1.5rem; padding:1.75rem;
  background:rgba(255,255,255,.07);
  border:1px solid rgba(255,255,255,.14);
  backdrop-filter:blur(14px);
  box-shadow:0 1.5rem 3rem rgba(0,0,0,.3);
}
.cd-cell{ display:flex; flex-direction:column; align-items:center; gap:.25rem;
  border-radius:.85rem; padding:.85rem .25rem; background:rgba(255,255,255,.06); }
.cd-cell b{ font-size:clamp(1.6rem,5vw,2.4rem); font-weight:900; line-height:1; font-family:"Inter",sans-serif; }
.cd-cell span{ font-size:.62rem; font-weight:800; letter-spacing:.12em; color:rgba(255,255,255,.55); }

/* ====== QUICK CARDS ====== */
.quick-card{
  position:relative; display:flex; flex-direction:column; align-items:center; text-align:center;
  gap:.5rem; padding:2rem 1.25rem 2.25rem; border-radius:1.25rem; background:#fff;
  box-shadow:0 1rem 2.5rem rgba(15,23,42,.08); border:1px solid var(--line);
  transition:transform .25s, box-shadow .25s;
}
.quick-card:hover{ transform:translateY(-.4rem); box-shadow:0 1.75rem 3.5rem rgba(15,23,42,.14); }
.quick-ico{ width:3.5rem; height:3.5rem; border-radius:1rem; display:grid; place-items:center; color:#fff; margin-bottom:.35rem; }
.quick-card b{ font-size:1.25rem; font-weight:900; letter-spacing:-.02em; color:var(--ink); }
.quick-card span{ font-size:.875rem; font-weight:600; color:#94a3b8; }
.quick-arrow{ width:1.1rem; height:1.1rem; color:#cbd5e1; transition:transform .25s, color .25s; }
.quick-card:hover .quick-arrow{ color:var(--accent); transform:translateX(.25rem); }

.notice-card{ padding:1.75rem; border-radius:1.25rem; background:#fff;
  box-shadow:0 1rem 2.5rem rgba(15,23,42,.08); border:1px solid var(--line); }
.notice-row{ display:flex; align-items:center; justify-content:space-between; gap:1rem;
  font-size:.9rem; padding-bottom:.65rem; border-bottom:1px dashed var(--line); }
.notice-row:last-child{ border-bottom:0; padding-bottom:0; }
.notice-row span{ min-width:0; flex:1; font-weight:700; color:#475569; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.notice-row em{ font-style:normal; font-weight:700; color:#cbd5e1; font-size:.8rem; flex-shrink:0; }

/* ====== CATEGORY CARDS ====== */
.cat-card{ background:#fff; border:1px solid var(--line); border-radius:1.5rem; padding:2rem;
  box-shadow:0 1rem 2.5rem rgba(15,23,42,.06); transition:transform .25s, box-shadow .25s; }
.cat-card:hover{ transform:translateY(-.3rem); box-shadow:0 1.75rem 3.5rem rgba(15,23,42,.12); }
.cat-ico{ width:3.75rem; height:3.75rem; border-radius:1.1rem; display:grid; place-items:center; color:#fff; flex-shrink:0; }
.cat-specs{ margin-top:1.5rem; display:grid; gap:.65rem; border-top:1px solid var(--line); padding-top:1.25rem; }
.cat-specs > div{ display:flex; align-items:center; justify-content:space-between; gap:1rem; }
.cat-specs dt{ font-size:.9rem; font-weight:700; color:#94a3b8; }
.cat-specs dd{ font-size:.95rem; font-weight:800; color:var(--ink); }

/* ====== AWARDS ====== */
.award-card{ position:relative; display:flex; flex-direction:column; align-items:center; text-align:center;
  gap:.4rem; padding:2rem 1rem; border-radius:1.25rem; background:#fff; border:1px solid var(--line);
  box-shadow:0 .75rem 2rem rgba(15,23,42,.06); transition:transform .25s; }
.award-card:hover{ transform:translateY(-.4rem); }
.award-ico{ width:2.5rem; height:2.5rem; color:var(--accent); margin-bottom:.25rem; }
.award-rank{ font-size:1.15rem; font-weight:900; color:var(--ink); }
.award-cnt{ font-size:.8rem; font-weight:700; color:#94a3b8; }
.award-prize{ margin-top:.5rem; font-size:1.05rem; font-weight:900; color:var(--accent); font-family:"Inter",sans-serif; }
.award-grand{ background:var(--ink); border-color:var(--ink); }
.award-grand .award-rank{ color:#fff; }
.award-grand .award-ico{ color:#ffd166; }
.award-grand .award-cnt{ color:rgba(255,255,255,.6); }
.award-grand .award-prize{ color:var(--accent2); }

/* ====== TIMELINE ====== */
.timeline{ position:relative; display:grid; gap:2rem; }
@media (min-width:1024px){
  .timeline{ grid-template-columns:repeat(5,minmax(0,1fr)); gap:1rem; }
  .timeline::before{ content:""; position:absolute; top:1.1rem; left:10%; right:10%; height:2px;
    background:linear-gradient(90deg,rgba(255,255,255,.15),var(--accent),rgba(255,255,255,.15)); }
}
.timeline li{ position:relative; padding-left:3rem; }
@media (min-width:1024px){ .timeline li{ padding-left:0; text-align:center; } }
.tl-dot{ position:absolute; left:0; top:0; width:2.25rem; height:2.25rem; border-radius:50%;
  display:grid; place-items:center; background:var(--ink2); border:2px solid var(--accent); color:#fff; z-index:1; }
@media (min-width:1024px){ .tl-dot{ position:relative; margin:0 auto .9rem; } }
.tl-dot-on{ background:var(--accent); border-color:#fff; }
.timeline b{ display:block; font-size:1.1rem; font-weight:900; }
.timeline time{ display:block; margin-top:.25rem; font-size:.85rem; font-weight:800; color:var(--accent2); }
.timeline p{ margin-top:.35rem; font-size:.85rem; color:rgba(255,255,255,.6); font-weight:500; }

/* ====== STEPS ====== */
.step-card{ position:relative; padding:2rem 1.5rem; border-radius:1.25rem; background:#fff;
  border:1px solid var(--line); box-shadow:0 .75rem 2rem rgba(15,23,42,.05); overflow:hidden; transition:transform .25s; }
.step-card:hover{ transform:translateY(-.3rem); }
.step-no{ position:absolute; top:1rem; right:1.25rem; font-size:2.5rem; font-weight:900;
  color:var(--line); font-family:"Inter",sans-serif; line-height:1; }
.step-ico{ width:3rem; height:3rem; border-radius:.9rem; display:grid; place-items:center;
  color:var(--accent); background:rgba(230,57,70,.1); }
.step-card b{ display:block; margin-top:1.1rem; font-size:1.15rem; font-weight:900; color:var(--ink); }
.step-card p{ margin-top:.5rem; font-size:.9rem; color:#64748b; font-weight:500; line-height:1.6; }

/* ====== JUDGING BARS ====== */
.bar-top{ display:flex; justify-content:space-between; font-weight:800; color:var(--ink); margin-bottom:.4rem; }
.bar-top em{ font-style:normal; color:var(--accent); font-family:"Inter",sans-serif; }
.bar-track{ height:.6rem; border-radius:999px; background:#e8ebef; overflow:hidden; }
.bar-fill{ display:block; height:100%; width:0; border-radius:999px;
  background:linear-gradient(90deg,var(--accent),var(--accent2)); transition:width 1.1s cubic-bezier(.22,1,.36,1); }
.bar-fill.on{ width:var(--w); }

/* ====== GALLERY ====== */
.gallery-swiper{ overflow:hidden; padding-bottom:.5rem; }
.gcard{ position:relative; display:block; border-radius:1.1rem; overflow:hidden; aspect-ratio:4/5; background:#e2e8f0; }
.gcard img{ width:100%; height:100%; object-fit:cover; transition:transform .5s; }
.gcard:hover img{ transform:scale(1.06); }
.gtag{ position:absolute; top:.75rem; left:.75rem; padding:.25rem .7rem; border-radius:999px;
  font-size:.72rem; font-weight:900; color:#fff; }
.gcap{ position:absolute; left:0; right:0; bottom:0; padding:1.5rem 1rem .9rem;
  background:linear-gradient(transparent, rgba(13,27,42,.9)); color:#fff; }
.gcap b{ display:block; font-size:1.05rem; font-weight:900; }
.gcap em{ font-style:normal; font-size:.78rem; font-weight:600; color:rgba(255,255,255,.75); }
.gallery-pg{ display:flex; justify-content:center; gap:.4rem; }
.gallery-pg .swiper-pagination-bullet{ width:.5rem; height:.5rem; background:#cbd5e1; opacity:1; }
.gallery-pg .swiper-pagination-bullet-active{ width:1.5rem; border-radius:999px; background:var(--accent); }

/* 네비 버튼 */
.nav-btn{ width:2.75rem; height:2.75rem; border-radius:999px; display:grid; place-items:center;
  background:#fff; border:1px solid var(--line); color:var(--ink); transition:.2s; }
.nav-btn:hover{ background:var(--ink); color:#fff; border-color:var(--ink); }

/* ====== JUDGES ====== */
.judge-card{ border-radius:1.25rem; overflow:hidden; background:#fff; border:1px solid var(--line);
  box-shadow:0 .75rem 2rem rgba(15,23,42,.05); transition:transform .25s; }
.judge-card:hover{ transform:translateY(-.3rem); }
.judge-card img{ width:100%; aspect-ratio:1/1; object-fit:cover; }
.judge-body{ position:relative; padding:1.25rem; }
.judge-body b{ display:block; font-size:1.05rem; font-weight:900; color:var(--ink); }
.judge-body span{ font-size:.82rem; font-weight:600; color:#94a3b8; }
.judge-q{ position:absolute; top:-1rem; right:1.25rem; width:2.25rem; height:2.25rem; border-radius:50%;
  display:grid; place-items:center; background:var(--accent); color:#fff; font-size:.85rem; }

/* ====== FAQ ====== */
.faq-item{ background:#fff; border:1px solid var(--line); border-radius:1rem; overflow:hidden; }
.faq-q{ width:100%; display:flex; align-items:center; justify-content:space-between; gap:1rem;
  padding:1.25rem 1.5rem; text-align:left; font-size:1.02rem; font-weight:800; color:var(--ink); cursor:pointer; }
.faq-icon{ width:1.25rem; height:1.25rem; color:var(--accent); flex-shrink:0; transition:transform .3s; }
.faq-item.open .faq-icon{ transform:rotate(45deg); }
.faq-a{ max-height:0; overflow:hidden; transition:max-height .35s ease; }
.faq-a p{ padding:0 1.5rem 1.35rem; color:#64748b; font-weight:500; line-height:1.7; }

/* ====== CTA BAND ====== */
.cta-band{ background:linear-gradient(120deg,var(--ink) 0%,var(--ink2) 60%,#1f3a5f 100%); }
.cta-band::after{ content:""; position:absolute; right:-6rem; top:-6rem; width:22rem; height:22rem;
  border-radius:50%; background:radial-gradient(circle,rgba(230,57,70,.35),transparent 70%); }

/* ====== FOOTER ====== */
.foot-sns{ width:2.5rem; height:2.5rem; border-radius:.75rem; display:grid; place-items:center;
  background:rgba(255,255,255,.08); color:#fff; transition:.2s; }
.foot-sns:hover{ background:var(--accent); }
.footer-select{ width:100%; height:3rem; border-radius:.75rem; padding:0 1rem;
  background-color:rgba(255,255,255,.07); border:1px solid rgba(255,255,255,.16); color:#fff;
  font-weight:700; font-size:.9rem; cursor:pointer; appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' fill='none' stroke='%23ffffff' stroke-width='2' viewBox='0 0 24 24'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");
  background-repeat:no-repeat; background-position:right 1rem center; }
.footer-select option{ color:#0d1b2a; }

/* ====== MOBILE DRAWER ====== */
.drawer-label{ font-size:.68rem; font-weight:900; letter-spacing:.18em; color:#cbd5e1; margin:.5rem 0; }
.drawer-link{ display:flex; align-items:center; justify-content:space-between; padding:.85rem .25rem;
  font-size:1.05rem; font-weight:800; color:var(--ink); border-bottom:1px solid var(--line); }
.drawer-link:active{ color:var(--accent); }

/* ====== POPUP ====== */
.popup-wrap{ position:fixed; inset:0; z-index:60; display:flex; align-items:center; justify-content:center; padding:1.25rem; }
.popup-wrap.hidden{ display:none; }
.popup-card{ position:relative; width:100%; max-width:24rem; background:#fff; border-radius:1.25rem;
  overflow:hidden; box-shadow:0 2rem 4rem rgba(0,0,0,.4); animation:popIn .35s ease; }
@keyframes popIn{ from{ opacity:0; transform:translateY(1.5rem) scale(.97); } to{ opacity:1; transform:none; } }
.popup-head{ display:flex; align-items:center; justify-content:space-between; padding:1rem 1.25rem; background:var(--ink); }
.popup-close{ width:2rem; height:2rem; border-radius:.6rem; display:grid; place-items:center;
  background:rgba(255,255,255,.12); color:#fff; }
.popup-img{ width:100%; height:9.5rem; object-fit:cover; }
.popup-body{ padding:1.25rem 1.5rem; }
.popup-foot{ display:grid; grid-template-columns:1fr 1fr; gap:.5rem; padding:0 1.5rem 1.5rem; }
.popup-today{ height:2.75rem; border-radius:.75rem; background:#f1f5f9; font-weight:800; color:#475569; }
.popup-ok{ height:2.75rem; border-radius:.75rem; background:var(--accent); color:#fff; font-weight:900;
  display:flex; align-items:center; justify-content:center; }

/* 모션 줄이기 환경 */
@media (prefers-reduced-motion:reduce){
  *{ animation-duration:.01ms!important; transition-duration:.01ms!important; }
}
