/* ===========================
   RESET & BASE
=========================== */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; font-size:16px; }
body { background:#0a0a0a; color:#f0f0f0; font-family:'Segoe UI',Arial,sans-serif; line-height:1.7; }
a { text-decoration:none; }
img { max-width:100%; }

/* ===========================
   COLOURS — VKR Yellow + Orange + Periwinkle
=========================== */
:root {
  --yellow:   #FFE800;
  --yellow-dark: #d4c000;
  --orange:   #E8420A;
  --orange-dark: #c03508;
  --blue:     #6272D4;
  --blue-dark: #4a5ab8;
  --blue-glow: rgba(98,114,212,0.18);
  --black:    #0a0a0a;
  --dark:     #111111;
  --dark2:    #181818;
  --dark3:    #202020;
  --border:   rgba(98,114,212,0.22);
  --text:     #f0f0f0;
  --muted:    #999;
  /* legacy alias */
  --red:      #E8420A;
  --red-dark: #c03508;
  --red-glow: rgba(232,66,10,0.15);
  --primary:  #6272D4;
  --accent:   #FFE800;
}

/* ===========================
   HEADER
=========================== */
header {
  position:fixed; top:0; left:0; width:100%; z-index:1000;
  background:rgba(10,10,10,0.97);
  backdrop-filter:blur(14px);
  border-bottom:2px solid var(--yellow);
  display:flex; align-items:center; justify-content:space-between;
  padding:10px 40px;
  transition:all .3s;
}
header.scrolled { padding:8px 40px; }

.logo-section { display:flex; align-items:center; gap:0; }
.logo-section img { width:75px; height:75px; object-fit:contain; }
.logo-divider {
  width:2px; height:50px;
  background:rgba(255,255,255,0.25);
  margin:0 12px;
  border-radius:2px;
}
.logo-text { display:flex; flex-direction:column; }
.logo-main { font-size:15px; font-weight:900; letter-spacing:1.5px; color:#fff; white-space:nowrap; }
.logo-sub  { font-size:10px; color:var(--yellow); letter-spacing:1px; font-weight:600; white-space:nowrap; margin-top:2px; }

nav { display:flex; align-items:center; gap:5px; }
nav a { color:#ccc; font-size:13px; font-weight:600; letter-spacing:.5px; padding:7px 12px; border-radius:6px; transition:all .2s; }
nav a:hover { color:#fff; background:rgba(98,114,212,0.15); }
.nav-cta { background:var(--orange) !important; color:#fff !important; padding:8px 18px !important; border-radius:6px !important; font-weight:800 !important; }
.nav-cta:hover { background:var(--orange-dark) !important; transform:translateY(-1px); }

.header-right { display:none; align-items:center; gap:12px; }
.store-icon-btn {
  display:flex; align-items:center; justify-content:center;
  width:38px; height:38px; border-radius:50%;
  background:var(--orange); color:#fff;
  font-size:16px; transition:.2s;
  border:2px solid var(--yellow);
}
.store-icon-btn:hover { background:var(--orange-dark); transform:translateY(-1px); }

.hamburger { display:none; flex-direction:column; gap:5px; background:none; border:none; cursor:pointer; padding:5px; }
.hamburger span { display:block; width:24px; height:2px; background:#fff; border-radius:2px; transition:.3s; }

/* ===========================
   HERO
=========================== */
.hero {
  position:relative; width:100%; height:100vh; min-height:500px;
  overflow:hidden; display:flex; align-items:center; justify-content:center;
}
.hero-slides { position:absolute; inset:0; }
.slide {
  position:absolute; inset:0;
  background-size:cover; background-position:center 20%;
  background-color:#181818;
  opacity:0; transition:opacity 1.2s ease-in-out;
}
.slide.active { opacity:1; }
.hero-overlay {
  position:absolute; inset:0; z-index:1;
  background:linear-gradient(to bottom,
    rgba(0,0,0,0.72) 0%,
    rgba(0,0,0,0.45) 40%,
    rgba(0,0,0,0.80) 100%);
}
.hero-content {
  position:relative; z-index:2;
  text-align:center; padding:0 20px; max-width:900px; margin:0 auto;
}
.hero-badge {
  display:inline-block;
  background:rgba(232,66,10,0.18);
  border:1px solid rgba(232,66,10,0.5);
  color:var(--yellow); font-size:12px; font-weight:700;
  letter-spacing:1px; padding:6px 16px; border-radius:50px;
  margin-bottom:20px; max-width:92vw; word-break:break-word;
}
@media(max-width:480px){
  .hero-badge { font-size:11px; letter-spacing:0.3px; padding:5px 12px; }
}
.hero-content h1 {
  font-size:clamp(38px,7vw,80px); font-weight:900;
  line-height:1.05; letter-spacing:-1px;
  color:#fff; text-shadow:0 4px 30px rgba(0,0,0,0.8);
  margin-bottom:15px;
}
.hero-accent { color:var(--yellow); }
.hero-tagline { font-size:clamp(14px,2vw,20px); color:#eee; letter-spacing:3px; margin-bottom:28px; text-shadow:0 2px 8px rgba(0,0,0,0.7); }
.hero-meta {
  display:flex; flex-wrap:wrap; gap:15px;
  justify-content:center; margin-bottom:32px;
}
.meta-item {
  display:flex; align-items:center; gap:8px;
  background:rgba(0,0,0,0.55); border:1px solid rgba(255,255,255,0.2);
  padding:8px 16px; border-radius:50px; font-size:13px; color:#fff;
  backdrop-filter:blur(4px);
}
.meta-item i { color:var(--yellow); }
.hero-actions { display:flex; gap:15px; justify-content:center; flex-wrap:wrap; margin-bottom:30px; }
.btn-primary {
  display:inline-flex; align-items:center; gap:8px;
  background:var(--orange); color:#fff; font-size:15px; font-weight:800;
  padding:14px 32px; border-radius:8px; border:none; cursor:pointer;
  transition:all .2s; letter-spacing:.5px;
}
.btn-primary:hover { background:var(--orange-dark); transform:translateY(-2px); box-shadow:0 8px 25px rgba(232,66,10,0.4); color:#fff; }
.btn-outline {
  display:inline-flex; align-items:center; gap:8px;
  background:rgba(0,0,0,0.4); color:#fff; font-size:15px; font-weight:700;
  padding:13px 30px; border-radius:8px; border:2px solid rgba(255,255,255,0.5);
  transition:all .2s; backdrop-filter:blur(4px);
}
.btn-outline:hover { border-color:var(--yellow); background:rgba(255,232,0,0.1); color:var(--yellow); }
.hero-socials { display:flex; gap:15px; justify-content:center; }
.hero-socials a {
  width:42px; height:42px; border-radius:50%;
  border:1px solid rgba(255,255,255,0.3); background:rgba(0,0,0,0.4);
  display:flex; align-items:center; justify-content:center;
  color:#fff; font-size:17px; transition:.2s;
}
.hero-socials a:hover { background:var(--orange); border-color:var(--orange); color:#fff; transform:translateY(-2px); }
.hero-scroll { position:absolute; bottom:25px; left:50%; transform:translateX(-50%); z-index:2; }
.hero-scroll span {
  display:block; width:2px; height:40px;
  background:linear-gradient(to bottom, var(--yellow), transparent);
  margin:0 auto; animation:scrollAnim 1.5s ease-in-out infinite;
}
@keyframes scrollAnim { 0%,100%{transform:scaleY(1);opacity:1} 50%{transform:scaleY(.5);opacity:.5} }

/* ===========================
   STATS BAR
=========================== */
.stats-bar {
  display:flex; justify-content:center; flex-wrap:wrap;
  background:var(--orange); padding:0;
  border-bottom:3px solid var(--yellow);
}
.stat {
  display:flex; flex-direction:column; align-items:center;
  padding:20px 35px; border-right:1px solid rgba(255,255,255,0.2);
  flex:1; min-width:120px;
}
.stat:last-child { border-right:none; }
.stat-num   { font-size:28px; font-weight:900; color:#fff; line-height:1; }
.stat-label { font-size:11px; color:rgba(255,255,255,0.85); letter-spacing:1px; margin-top:4px; text-transform:uppercase; }

/* ===========================
   SECTIONS
=========================== */
.section { padding:90px 5%; }
.section-dark { background:var(--dark); }
.section-inner { max-width:1100px; margin:0 auto; }
.section-label {
  font-size:11px; font-weight:700; letter-spacing:3px;
  color:var(--yellow); margin-bottom:10px; text-transform:uppercase;
}
.section-title {
  font-size:clamp(28px,4vw,44px); font-weight:900;
  color:#fff; margin-bottom:45px; line-height:1.1;
}
.red  { color:var(--orange); }
.red-icon { color:var(--orange); font-size:28px; margin-bottom:12px; display:block; }

/* ===========================
   ABOUT
=========================== */
.about-grid { display:grid; grid-template-columns:1fr 1fr; gap:40px; align-items:start; }
.about-text p { color:#ddd; margin-bottom:15px; font-size:15px; }
.about-tags { display:flex; flex-wrap:wrap; gap:10px; margin-top:20px; }
.about-tags span {
  background:var(--dark3); border:1px solid var(--border);
  padding:7px 15px; border-radius:50px; font-size:13px; color:#eee;
}
.about-card {
  background:var(--dark2); border:1px solid var(--border);
  border-left:3px solid var(--yellow);
  border-radius:12px; padding:30px;
}
.about-card-icon { font-size:36px; margin-bottom:15px; }
.about-card h3 { color:var(--yellow); font-size:18px; margin-bottom:12px; }
.about-card p  { color:#ccc; font-size:14px; }

/* WHAT WE STAND FOR */
.stand-for-btn {
  display:inline-flex; align-items:center; gap:8px;
  margin-top:22px; background:var(--blue);
  color:#fff; font-size:14px; font-weight:700;
  padding:11px 22px; border-radius:8px; border:none; cursor:pointer;
  transition:.2s;
}
.stand-for-btn:hover { background:var(--blue-dark); transform:translateY(-1px); }
.stand-for-box {
  display:none; margin-top:18px;
  background:rgba(98,114,212,0.1); border:1px solid rgba(98,114,212,0.3);
  border-radius:10px; padding:22px;
}
.stand-for-box.open { display:block; }
.stand-for-box p { color:#ddd; font-size:14px; line-height:1.8; }

/* ===========================
   EVENT DETAILS
=========================== */
.event-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(200px,1fr)); gap:20px; margin-bottom:35px; }
.event-detail-card {
  background:var(--dark2); border:1px solid var(--border);
  border-radius:12px; padding:25px 20px; text-align:center; transition:.2s;
}
.event-detail-card:hover { border-color:var(--yellow); transform:translateY(-3px); }
.event-detail-card h4 { color:var(--yellow); font-size:13px; letter-spacing:1px; margin-bottom:8px; text-transform:uppercase; }
.event-detail-card p  { color:#ddd; font-size:14px; line-height:1.6; }
.guidelines-box {
  background:rgba(232,66,10,0.07); border:1px solid rgba(232,66,10,0.25);
  border-radius:12px; padding:28px 30px;
}
.guidelines-box h3 { color:#fff; font-size:18px; margin-bottom:15px; }
.guidelines-box ul { list-style:none; display:grid; grid-template-columns:1fr 1fr; gap:10px; }
.guidelines-box ul li { color:#ddd; font-size:14px; padding-left:18px; position:relative; }
.guidelines-box ul li::before { content:"→"; color:var(--yellow); position:absolute; left:0; }

/* ===========================
   INCLUDES
=========================== */
.includes-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(220px,1fr)); gap:20px; margin-bottom:40px; }
.include-card {
  background:var(--dark2); border:1px solid var(--border);
  border-radius:12px; padding:25px 20px; text-align:center; transition:.2s;
}
.include-card:hover { border-color:var(--yellow); transform:translateY(-4px); box-shadow:0 8px 25px rgba(255,232,0,0.08); }
.include-icon  { font-size:36px; margin-bottom:12px; }
.include-card h4 { color:#fff; font-size:15px; margin-bottom:8px; }
.include-card p  { color:#999; font-size:13px; }
.includes-cta { text-align:center; background:var(--dark2); border:1px solid var(--border); border-radius:12px; padding:30px; }
.includes-cta p { color:#ddd; margin-bottom:20px; font-size:15px; }

/* ===========================
   TEAM
=========================== */
.team-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(260px,1fr)); gap:25px; margin-bottom:35px; }
.team-card {
  background:var(--dark2); border:1px solid var(--border);
  border-radius:14px; padding:30px; text-align:center; transition:.2s;
}
.team-card:hover { border-color:var(--yellow); transform:translateY(-4px); }
.team-avatar {
  width:70px; height:70px; border-radius:50%;
  background:var(--orange); color:#fff;
  font-size:22px; font-weight:800;
  display:flex; align-items:center; justify-content:center;
  margin:0 auto 15px;
}
.team-card h3   { color:#fff; font-size:20px; margin-bottom:5px; }
.team-role {
  display:inline-block; background:rgba(232,66,10,0.12);
  color:var(--orange); font-size:12px; padding:4px 12px;
  border-radius:50px; margin-bottom:12px; letter-spacing:.5px;
}
.team-card p { color:#999; font-size:13px; margin-bottom:15px; }
.team-contact {
  display:inline-flex; align-items:center; gap:7px;
  color:var(--yellow); font-size:13px; font-weight:600;
}
.team-avatar-wrap {
  width:100px; height:100px; margin:0 auto 15px;
  border-radius:50%; overflow:hidden; border:3px solid var(--orange);
}
.team-photo { width:100%; height:100%; object-fit:cover; border-radius:50%; }
.team-card .team-avatar {
  width:100px; height:100px; border-radius:50%;
  background:var(--orange); color:#fff;
  font-size:28px; font-weight:800;
  align-items:center; justify-content:center; margin:0 auto 15px;
}

/* SUPPORT TEAM 2x2 */
.support-team-grid {
  display:grid; grid-template-columns:1fr 1fr;
  gap:20px; margin:35px 0;
}
.support-card {
  background:var(--dark3); border:1px solid var(--border);
  border-radius:12px; padding:20px; text-align:center; transition:.2s;
  display:flex; flex-direction:column; align-items:center;
}
.support-card:hover { border-color:var(--yellow); transform:translateY(-3px); }
.support-avatar-wrap {
  width:75px; height:75px; margin:0 auto 12px;
  border-radius:50%; overflow:hidden; border:2px solid var(--orange);
}
.support-card h4 { color:#fff; font-size:16px; margin-bottom:4px; }
.support-card .team-role { color:var(--orange); font-size:11px; margin-bottom:8px; }
.support-card p  { color:#999; font-size:12px; line-height:1.5; }

.support-section { background:var(--dark2); border:1px solid var(--border); border-radius:12px; padding:30px; text-align:center; }
.support-section h3 { color:var(--yellow); font-size:18px; margin-bottom:15px; }
.support-names { color:#bbb; font-size:14px; line-height:2; }

/* ===========================
   GALLERY
=========================== */
.gallery-coming {
  background:var(--dark2); border:2px dashed rgba(255,232,0,0.2);
  border-radius:14px; padding:60px 30px; text-align:center;
}
.gallery-icon { font-size:60px; margin-bottom:20px; }
.gallery-coming h3 { color:#fff; font-size:24px; margin-bottom:12px; }
.gallery-coming p  { color:#999; font-size:15px; }

/* ===========================
   PARTNERS
=========================== */
.partners-grid { display:grid; grid-template-columns:1fr 1fr; gap:25px; }
.partner-info-card {
  background:var(--dark2); border:1px solid var(--border);
  border-radius:12px; padding:30px;
}
.partner-info-card h3 { color:#fff; font-size:18px; margin-bottom:10px; }
.partner-info-card p  { color:#bbb; font-size:14px; margin-bottom:8px; }
.btn-partner {
  display:inline-flex; align-items:center; gap:8px;
  background:#25d366; color:#fff; font-weight:700;
  padding:11px 22px; border-radius:8px; margin-top:15px;
  transition:.2s; font-size:14px;
}
.btn-partner:hover { background:#1da851; transform:translateY(-1px); color:#fff; }

/* ===========================
   CONTACT
=========================== */
.contact-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(220px,1fr)); gap:20px; margin-bottom:35px; }
.contact-card {
  background:var(--dark2); border:1px solid var(--border);
  border-radius:12px; padding:25px; text-align:center;
}
.contact-card h4 { color:var(--yellow); font-size:13px; letter-spacing:1px; margin:10px 0 12px; text-transform:uppercase; }
.contact-card a, .contact-card p { display:block; color:#bbb; font-size:14px; margin-bottom:6px; }
.contact-card a:hover { color:var(--yellow); }
.social-row { display:flex; flex-wrap:wrap; gap:12px; justify-content:center; }
.social-btn {
  display:inline-flex; align-items:center; gap:8px;
  padding:11px 22px; border-radius:8px;
  font-weight:700; font-size:14px; transition:.2s;
}
.social-btn:hover { transform:translateY(-2px); opacity:.9; }
.whatsapp  { background:#25d366; color:#fff; }
.instagram { background:linear-gradient(45deg,#f09433,#e6683c,#dc2743,#cc2366,#bc1888); color:#fff; }
.facebook  { background:#1877f2; color:#fff; }
.youtube   { background:#ff0000; color:#fff; }

/* ===========================
   FOOTER
=========================== */
footer { background:#000; border-top:2px solid var(--orange); padding:40px 5%; }
.footer-inner  { max-width:1100px; margin:0 auto; text-align:center; }
.footer-logo   { display:flex; align-items:center; gap:15px; justify-content:center; margin-bottom:20px; }
.footer-logo img { width:50px; height:50px; object-fit:contain; }
.footer-name   { display:block; font-size:16px; font-weight:800; color:#fff; letter-spacing:1.5px; }
.footer-tag    { display:block; font-size:12px; color:var(--yellow); letter-spacing:2px; }
.footer-links  { display:flex; gap:20px; justify-content:center; flex-wrap:wrap; margin-bottom:20px; }
.footer-links a { color:#666; font-size:13px; transition:.2s; }
.footer-links a:hover { color:var(--yellow); }
.footer-socials { display:flex; gap:15px; justify-content:center; margin-bottom:20px; }
.footer-socials a { color:#555; font-size:18px; transition:.2s; }
.footer-socials a:hover { color:var(--yellow); transform:translateY(-2px); }
.footer-copy   { color:#444; font-size:12px; letter-spacing:1px; }

/* ===========================
   REGISTER / ORDER PAGE HERO
=========================== */
.reg-hero {
  background:linear-gradient(135deg, #0a0a0a 0%, #1a1000 50%, #0a0a0a 100%);
  border-bottom:1px solid rgba(232,66,10,0.3);
  padding:120px 5% 50px; text-align:center;
}
.reg-hero-content { max-width:700px; margin:0 auto; }
.reg-hero h1 { font-size:clamp(28px,5vw,50px); font-weight:900; color:#fff; margin:15px 0; }
.reg-hero-meta { display:flex; flex-wrap:wrap; gap:15px; justify-content:center; margin-top:20px; }
.reg-hero-meta span {
  display:flex; align-items:center; gap:7px;
  background:rgba(255,232,0,0.07); border:1px solid rgba(255,232,0,0.2);
  padding:7px 15px; border-radius:50px; font-size:13px; color:#eee;
}
.reg-hero-meta i { color:var(--yellow); }

.reg-container { max-width:820px; margin:0 auto; padding:40px 20px 60px; }
.reg-fee-banner {
  background:var(--orange); color:#fff;
  display:flex; align-items:center; justify-content:center;
  gap:20px; flex-wrap:wrap;
  padding:14px 20px; border-radius:10px; margin-bottom:25px;
  font-size:15px; border-bottom:3px solid var(--yellow);
}
.fee-divider { opacity:.5; }

.form-card {
  background:var(--dark2); border:1px solid var(--border);
  border-radius:14px; padding:30px; margin-bottom:22px;
}
.form-card-header { display:flex; align-items:center; gap:12px; margin-bottom:25px; border-bottom:1px solid var(--border); padding-bottom:15px; }
.form-card-header i  { font-size:22px; }
.form-card-header h3 { color:#fff; font-size:18px; }

.form-row { display:grid; grid-template-columns:1fr 1fr; gap:15px; }
.form-group { margin-bottom:18px; }
.form-group label { display:block; color:#bbb; font-size:13px; font-weight:600; margin-bottom:7px; }
.form-group input[type="text"],
.form-group input[type="tel"],
.form-group input[type="email"],
.form-group input[type="date"],
.form-group input[type="number"],
.form-group textarea {
  width:100%; padding:11px 15px;
  background:var(--dark3); border:1px solid rgba(255,255,255,0.1);
  border-radius:8px; color:#fff; font-size:14px; transition:border-color .2s;
}
.form-group input:focus, .form-group textarea:focus { outline:none; border-color:var(--yellow); box-shadow:0 0 0 2px rgba(255,232,0,0.1); }
.form-group input[type="file"] {
  width:100%; padding:10px; background:var(--dark3);
  border:2px dashed rgba(232,66,10,0.4); border-radius:8px;
  color:#bbb; cursor:pointer; font-size:13px;
}
.form-group small { color:#555; font-size:12px; margin-top:5px; display:block; }
.req { color:var(--orange); }
.opt { color:#555; font-size:11px; font-weight:400; }

.radio-group { display:flex; flex-wrap:wrap; gap:10px; margin-top:5px; }
.radio-pill {
  display:flex; align-items:center; gap:7px;
  background:var(--dark3); border:1px solid rgba(255,255,255,0.1);
  padding:8px 15px; border-radius:50px; cursor:pointer;
  font-size:13px; color:#ccc; transition:.2s;
}
.radio-pill:hover { border-color:var(--yellow); color:#fff; }
.radio-pill input { accent-color:var(--orange); }

.size-group { display:flex; flex-wrap:wrap; gap:10px; margin-top:5px; }
.size-pill  { cursor:pointer; }
.size-pill input { display:none; }
.size-pill span {
  display:flex; align-items:center; justify-content:center;
  width:55px; height:45px;
  background:var(--dark3); border:1px solid rgba(255,255,255,0.1);
  border-radius:8px; font-size:13px; font-weight:700; color:#bbb; transition:.2s;
}
.size-pill:hover span { border-color:var(--yellow); color:#fff; }
.size-pill input:checked + span { background:var(--orange); border-color:var(--yellow); color:#fff; }

.payment-card { background:rgba(232,66,10,0.05); border-color:rgba(232,66,10,0.25); }
.payment-box {
  display:flex; align-items:center; justify-content:space-around;
  gap:30px; flex-wrap:wrap; margin-bottom:20px;
  background:var(--dark3); border-radius:10px; padding:25px;
}
.payment-title  { color:#888; font-size:12px; letter-spacing:1px; text-transform:uppercase; margin-bottom:5px; }
.payment-number { font-size:34px; font-weight:900; color:var(--yellow); letter-spacing:2px; }
.payment-name   { color:#888; font-size:13px; margin-top:3px; }
.fee-info { display:flex; gap:15px; margin-top:12px; }
.fee-info span  { background:rgba(255,232,0,0.07); border:1px solid rgba(255,232,0,0.2); padding:6px 14px; border-radius:50px; font-size:13px; color:#eee; }
.payment-right img { width:140px; height:140px; object-fit:contain; border:2px solid var(--orange); border-radius:10px; background:#fff; padding:5px; }
.payment-right p { text-align:center; color:#555; font-size:12px; margin-top:6px; }
.payment-note {
  background:rgba(255,232,0,0.06); border:1px solid rgba(255,232,0,0.2);
  border-radius:8px; padding:12px 16px; font-size:13px; color:#ddd;
  margin-bottom:18px; display:flex; align-items:flex-start; gap:8px;
}
.payment-note i { color:var(--yellow); margin-top:2px; flex-shrink:0; }

.terms-list { display:flex; flex-direction:column; gap:14px; }
.check-label { display:flex; align-items:flex-start; gap:10px; cursor:pointer; font-size:14px; color:#bbb; }
.check-label input { accent-color:var(--orange); width:17px; height:17px; margin-top:2px; flex-shrink:0; }

.form-actions { display:flex; gap:15px; justify-content:center; flex-wrap:wrap; margin-top:5px; }
.btn-submit { font-size:16px; padding:15px 40px; }
.btn-reset {
  display:inline-flex; align-items:center; gap:8px;
  background:var(--dark3); color:#bbb; border:1px solid var(--border);
  padding:14px 28px; border-radius:8px; cursor:pointer;
  font-size:14px; font-weight:600; transition:.2s;
}
.btn-reset:hover { background:var(--dark2); color:#fff; border-color:var(--yellow); }

.success-screen { max-width:600px; margin:80px auto 40px; padding:20px; }
.success-inner {
  background:var(--dark2); border:1px solid rgba(255,232,0,0.25);
  border-radius:16px; padding:50px 30px; text-align:center;
}
.success-icon    { font-size:60px; margin-bottom:20px; }
.success-inner h2 { color:var(--yellow); font-size:28px; margin-bottom:15px; }
.success-inner p  { color:#bbb; font-size:15px; margin-bottom:10px; }
.reg-id-text     { color:var(--orange); font-size:20px; font-weight:800; margin:10px 0; }

.total-display {
  background:rgba(255,232,0,0.08); border:1px solid rgba(255,232,0,0.25);
  border-radius:8px; padding:11px 15px;
  color:var(--yellow); font-size:22px; font-weight:900;
}

/* LOADING SPINNER */
.loading-box {
  display:flex; align-items:center; justify-content:center; gap:12px;
  text-align:center; padding:18px; color:var(--yellow); font-weight:700;
  background:rgba(255,232,0,0.06); border:1px solid rgba(255,232,0,0.2);
  border-radius:10px; font-size:14px;
}
.loading-spinner {
  width:20px; height:20px; border-radius:50%;
  border:3px solid rgba(255,232,0,0.25);
  border-top-color:var(--yellow);
  animation:spin .8s linear infinite;
  flex-shrink:0;
}
@keyframes spin { to { transform:rotate(360deg); } }

/* ===========================
   VKR STORE
=========================== */
.store-sub { color:#999; font-size:15px; margin-bottom:35px; text-align:center; }
.store-grid {
  display:grid; grid-template-columns:repeat(auto-fill,minmax(260px,1fr));
  gap:25px; margin-bottom:30px;
}
.product-card {
  background:var(--dark2); border:1px solid var(--border);
  border-radius:14px; overflow:hidden; transition:.2s;
}
.product-card:hover { border-color:var(--yellow); transform:translateY(-4px); box-shadow:0 10px 30px rgba(255,232,0,0.08); }
.product-img-wrap { position:relative; width:100%; height:220px; background:var(--dark3); }
.product-img { width:100%; height:100%; object-fit:cover; }
.product-placeholder {
  width:100%; height:100%;
  flex-direction:column; align-items:center; justify-content:center; color:#444; gap:10px;
}
.product-placeholder i { font-size:48px; }
.product-badge {
  position:absolute; top:12px; left:12px;
  background:var(--orange); color:#fff;
  font-size:11px; font-weight:800; letter-spacing:1px;
  padding:4px 10px; border-radius:50px;
}
.product-info   { padding:20px; }
.product-info h3 { color:#fff; font-size:17px; margin-bottom:8px; }
.product-desc   { color:#888; font-size:13px; margin-bottom:12px; line-height:1.6; }
.product-sizes  { display:flex; gap:6px; flex-wrap:wrap; margin-bottom:15px; }
.product-sizes span {
  background:var(--dark3); border:1px solid var(--border);
  color:#bbb; font-size:11px; font-weight:700; padding:4px 10px; border-radius:5px;
}
.product-footer { display:flex; align-items:center; justify-content:space-between; }
.product-price  { color:var(--yellow); font-size:24px; font-weight:900; }
.btn-order {
  background:var(--orange); color:#fff; font-size:13px; font-weight:700;
  padding:9px 18px; border-radius:8px; transition:.2s; border:none;
}
.btn-order:hover { background:var(--orange-dark); color:#fff; transform:translateY(-1px); }
.store-note {
  display:flex; align-items:flex-start; gap:10px;
  background:rgba(255,255,255,0.03); border:1px solid var(--border);
  border-radius:10px; padding:15px 18px; color:#888; font-size:13px;
}
.store-note i { color:var(--yellow); margin-top:2px; flex-shrink:0; }

/* T-SHIRT SLIDER */
.tshirt-slider { position:relative; width:100%; height:100%; }
.tslide { position:absolute; inset:0; opacity:0; transition:opacity .5s ease; }
.tslide.active { opacity:1; }
.tslide img { width:100%; height:100%; object-fit:cover; }
.tslider-btn {
  position:absolute; top:50%; transform:translateY(-50%);
  background:rgba(0,0,0,0.55); border:none; color:#fff;
  width:32px; height:32px; border-radius:50%; font-size:13px;
  cursor:pointer; z-index:5; display:flex; align-items:center; justify-content:center;
  transition:.2s;
}
.tslider-btn:hover { background:var(--orange); }
.tslider-prev { left:8px; }
.tslider-next { right:8px; }
.tslider-dots {
  position:absolute; bottom:8px; left:50%; transform:translateX(-50%);
  display:flex; gap:5px; z-index:5;
}
.tdot {
  width:7px; height:7px; border-radius:50%;
  background:rgba(255,255,255,0.4); cursor:pointer; transition:.2s;
}
.tdot.active { background:var(--yellow); }

/* COMING SOON PRODUCT */
.product-coming {
  background:var(--dark2); border:1px solid var(--border);
  border-radius:14px; overflow:hidden; transition:.2s; opacity:.75;
}
.product-coming:hover { border-color:var(--blue); transform:translateY(-2px); opacity:1; }
.product-coming .product-badge { background:var(--blue); }
.coming-placeholder {
  width:100%; height:180px; background:var(--dark3);
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  gap:10px; color:#555;
}
.coming-placeholder i { font-size:40px; }
.coming-placeholder span { font-size:12px; letter-spacing:1px; }

/* ===========================
   GALLERY PAGE
=========================== */
.gallery-section { padding:50px 5% 80px; }
.gallery-inner   { max-width:1100px; margin:0 auto; }
.carousel-wrap {
  position:relative; width:100%; border-radius:14px; overflow:hidden;
  background:var(--dark2); margin-bottom:15px; border:1px solid var(--border);
}
.carousel-main  { position:relative; width:100%; height:520px; }
.carousel-slide {
  position:absolute; inset:0; display:flex; align-items:center; justify-content:center;
  opacity:0; transition:opacity .5s ease; cursor:pointer;
}
.carousel-slide.active { opacity:1; }
.carousel-slide img { width:100%; height:100%; object-fit:contain; background:#111; }
.carousel-btn {
  position:absolute; top:50%; transform:translateY(-50%);
  background:rgba(232,66,10,0.7); border:none; color:#fff;
  width:45px; height:45px; border-radius:50%; font-size:18px; cursor:pointer; z-index:10;
  display:flex; align-items:center; justify-content:center; transition:.2s;
}
.carousel-btn:hover { background:var(--orange); }
.carousel-prev { left:15px; }
.carousel-next { right:15px; }
.carousel-counter {
  position:absolute; bottom:15px; right:15px;
  background:rgba(0,0,0,0.7); color:#fff; font-size:13px;
  padding:5px 12px; border-radius:50px;
}
.thumb-strip { display:flex; gap:8px; overflow-x:auto; padding:5px 0 10px; scroll-behavior:smooth; }
.thumb-strip::-webkit-scrollbar { height:4px; }
.thumb-strip::-webkit-scrollbar-track { background:var(--dark2); border-radius:2px; }
.thumb-strip::-webkit-scrollbar-thumb { background:var(--orange); border-radius:2px; }
.thumb-item {
  flex-shrink:0; width:80px; height:60px; border-radius:8px; overflow:hidden;
  border:2px solid transparent; cursor:pointer; transition:.2s; opacity:.6;
}
.thumb-item:hover { opacity:1; border-color:rgba(255,232,0,0.5); }
.thumb-item.active { border-color:var(--yellow); opacity:1; }
.thumb-item img { width:100%; height:100%; object-fit:cover; }
.gallery-grid-full {
  display:grid; grid-template-columns:repeat(auto-fill,minmax(220px,1fr)); gap:12px;
}
.gallery-cell {
  aspect-ratio:1; border-radius:10px; overflow:hidden;
  cursor:pointer; background:var(--dark2); border:1px solid var(--border); transition:.2s;
}
.gallery-cell:hover { transform:scale(1.03); border-color:var(--yellow); }
.gallery-cell img { width:100%; height:100%; object-fit:cover; transition:.3s; }
.gallery-cell:hover img { transform:scale(1.05); }
.lightbox {
  position:fixed; inset:0; z-index:9999; background:rgba(0,0,0,0.96);
  display:none; align-items:center; justify-content:center; backdrop-filter:blur(8px);
}
.lightbox.open { display:flex; }
.lightbox-img { max-width:90vw; max-height:85vh; object-fit:contain; border-radius:8px; }
.lightbox-close {
  position:absolute; top:20px; right:20px;
  background:rgba(232,66,10,0.4); border:none; color:#fff;
  width:44px; height:44px; border-radius:50%; font-size:20px; cursor:pointer; transition:.2s;
  display:flex; align-items:center; justify-content:center;
}
.lightbox-close:hover { background:var(--orange); }
.lightbox-prev, .lightbox-next {
  position:absolute; top:50%; transform:translateY(-50%);
  background:rgba(232,66,10,0.4); border:none; color:#fff;
  width:50px; height:50px; border-radius:50%; font-size:20px; cursor:pointer; transition:.2s;
  display:flex; align-items:center; justify-content:center;
}
.lightbox-prev { left:20px; }
.lightbox-next { right:20px; }
.lightbox-prev:hover, .lightbox-next:hover { background:var(--orange); }
.lightbox-counter {
  position:absolute; bottom:20px; left:50%; transform:translateX(-50%);
  color:#fff; font-size:14px; background:rgba(0,0,0,0.6); padding:6px 16px; border-radius:50px;
}

/* ===========================
   MOBILE
=========================== */
@media(max-width:900px){
  header { padding:10px 20px; }
  .header-right { display:flex; }
  nav { display:none; position:absolute; top:100%; left:0; width:100%; background:#0f0f0f; flex-direction:column; padding:15px; gap:5px; border-bottom:2px solid var(--yellow); }
  nav.open { display:flex; }
  nav a { padding:12px 15px; width:100%; border-radius:8px; font-size:14px; }
  .nav-cta { text-align:center; }
  .hamburger { display:flex; }
  .about-grid { grid-template-columns:1fr; }
  .guidelines-box ul { grid-template-columns:1fr; }
  .partners-grid { grid-template-columns:1fr; }
  .form-row { grid-template-columns:1fr; }
  .payment-box { flex-direction:column; text-align:center; }
  .fee-info { justify-content:center; }
  .form-actions { flex-direction:column; align-items:center; }
  .btn-submit, .btn-reset { width:100%; max-width:340px; justify-content:center; }
  .stat { padding:15px 20px; }
  .stat-num { font-size:22px; }
}
@media(max-width:600px){
  .hero { height:100svh; min-height:100svh; }
  .hero-content h1 { font-size:32px; }
  .section { padding:60px 5%; }
  .section-title { font-size:26px; }
  .stats-bar { gap:0; }
  .stat { min-width:50%; border-bottom:1px solid rgba(255,255,255,0.1); }
  .reg-hero { padding:100px 5% 35px; }
  .reg-container { padding:25px 15px 50px; }
  .form-card { padding:20px 15px; }
  .store-grid { grid-template-columns:1fr; }
  .support-team-grid { grid-template-columns:1fr 1fr; gap:12px; }
  .support-card { padding:15px 10px; }
  .support-avatar-wrap { width:60px; height:60px; }
  .support-card h4 { font-size:14px; }
  .carousel-main { height:280px; }
  .gallery-grid-full { grid-template-columns:repeat(auto-fill,minmax(140px,1fr)); gap:8px; }
  .lightbox-prev { left:8px; }
  .lightbox-next { right:8px; }
}
@media(max-width:480px){
  .logo-main { font-size:12px; letter-spacing:.3px; white-space:nowrap; }
  .logo-sub  { font-size:8.5px; letter-spacing:0px; white-space:nowrap; }
  .logo-section img { width:55px; height:55px; }
  .logo-divider { height:38px; margin:0 8px; }
  header { padding:6px 12px; }
}
