/* SMAS Islamic Centre Demak — Clean Header, No Parallax
   Tema: Hijau Emerald #0e4d2f + Gold #d4a843
   ============================================================ */
:root {
    --green:        #0e4d2f;
    --green-mid:    #166640;
    --green-light:  #1d8050;
    --green-pale:   #e6f7ed;

    --gold:         #d4a843;
    --gold-light:   #f0d882;
    --gold-bg:      #fdf8ec;

    --accent-green: #16a34a;
    --accent-red:   #dc2626;
    --red-bg:       #fef2f2;
    --red-border:   #fecaca;

    --white:        #ffffff;
    --gray-50:      #f6f7fb;
    --gray-100:     #f1f4f9;
    --gray-200:     #e2e8f0;
    --gray-300:     #cbd5e1;
    --gray-400:     #94a3b8;
    --gray-500:     #64748b;
    --gray-700:     #334155;
    --gray-900:     #0f172a;

    --radius-sm:  8px;
    --radius-md:  12px;
    --radius-lg:  16px;
    --radius-xl:  22px;

    --shadow-sm:  0 1px 3px rgba(0,0,0,.07);
    --shadow-md:  0 4px 16px rgba(0,0,0,.10);
    --shadow-lg:  0 10px 32px rgba(0,0,0,.13);

    --font-body:    'Inter', system-ui, sans-serif;
    --font-display: 'Lora', Georgia, serif;
}

*, *::before, *::after { box-sizing:border-box; margin:0; padding:0; }
html { -webkit-text-size-adjust:100%; scroll-behavior:smooth; }
body {
    font-family: var(--font-body);
    background: var(--gray-50);
    color: var(--gray-900);
    min-height: 100vh;
    display: flex;
    flex-direction: column;
    -webkit-font-smoothing: antialiased;
    overflow-x: hidden;
}
body.modal-open {
    overflow: hidden; /* Mencegah background scroll saat popup aktif */
}
button { cursor:pointer; font-family:inherit; }
input, button { -webkit-appearance:none; appearance:none; }

/* ============================================================
   HEADER RESMI
   ============================================================ */
.site-header {
    background: var(--green);
    position: sticky;
    top: 0;
    z-index: 100;
    box-shadow: 0 2px 12px rgba(0,0,0,.25);
}

.header-top { padding: 12px 16px 0; }

.emblem-wrap {
    display: flex;
    align-items: center;
    gap: 12px;
    max-width: 640px;
    margin: 0 auto;
}

.school-emblem { flex-shrink: 0; }
.emblem-img {
    /* fluid: min 40px, ideal 10vw, max 58px */
    width: clamp(40px, 10vw, 58px);
    height: clamp(40px, 10vw, 58px);
    object-fit: contain;
    display: block;
    filter: drop-shadow(0 2px 6px rgba(0,0,0,.3));
}

.school-titles  { display:flex; flex-direction:column; gap:2px; overflow:hidden; }
.school-name-sm {
    font-size: 9px; font-weight: 600;
    letter-spacing: .12em; text-transform: uppercase;
    color: rgba(255,255,255,.5); line-height: 1.4;
}
.school-name-main {
    font-family: var(--font-display);
    font-size: 15px; font-weight: 700;
    color: var(--gold-light); line-height: 1.2;
    white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.school-address {
    font-size: 9.5px;
    color: rgba(255,255,255,.4);
    white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}

.header-divider {
    height: 1px;
    background: rgba(212,168,67,.25);
    margin: 10px 16px;
    max-width: 640px;
    margin-left: auto; margin-right: auto;
}

.header-title-band {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 6px 16px 8px;
    max-width: 640px;
    margin: 0 auto;
    gap: 8px;
}
.header-event-title {
    font-size: 11px; font-weight: 700;
    letter-spacing: .12em; text-transform: uppercase;
    color: var(--gold);
}
.header-year-badge {
    background: var(--gold);
    color: var(--green);
    font-size: 10px; font-weight: 800;
    padding: 3px 12px; border-radius: 20px;
    letter-spacing: .05em; white-space: nowrap; flex-shrink: 0;
}

/* ============================================================
   MAIN
   ============================================================ */
.main-wrap {
    flex: 1; width: 100%; max-width: 480px;
    margin: 0 auto; padding: 20px 16px 36px;
}
.page { display:flex; flex-direction:column; gap:16px; }

/* ============================================================
   COUNTDOWN CARD
   ============================================================ */
.countdown-card {
    overflow: hidden;
    border: none;
}

.cd-header {
    background: linear-gradient(145deg, var(--green) 0%, var(--green-mid) 100%);
    padding: 22px 20px 18px;
    text-align: center;
}
.cd-lock-icon   { font-size: 32px; margin-bottom: 8px; display: block; }
.cd-title       { font-family: var(--font-display); font-size: 18px; font-weight: 700; color: var(--white); margin-bottom: 5px; }
.cd-subtitle    { font-size: 12px; color: rgba(255,255,255,.65); line-height: 1.5; }
.cd-subtitle strong { color: var(--gold-light); }

/* Units row */
.cd-units {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: clamp(3px, 1.5vw, 6px);
    padding: 20px 14px;
    background: var(--white);
}
.cd-unit {
    display: flex; flex-direction: column; align-items: center; gap: 4px;
    background: var(--green);
    border-radius: var(--radius-md);
    padding: 12px 6px;
    flex: 1;
    min-width: 0; /* Allow shrinking below min-content */
    box-shadow: 0 4px 14px rgba(14,77,47,.25);
}
.cd-number {
    font-family: var(--font-display);
    font-size: clamp(22px, 6vw, 30px);
    font-weight: 700;
    color: var(--gold-light);
    line-height: 1;
    letter-spacing: .02em;
    transition: transform .15s;
}
.cd-label {
    font-size: clamp(8px, 2.5vw, 9.5px);
    font-weight: 700;
    letter-spacing: .05em; text-transform: uppercase;
    color: rgba(255,255,255,.55);
}
.cd-sep {
    font-size: clamp(16px, 4vw, 24px);
    font-weight: 700;
    color: var(--green); padding-bottom: 14px;
    opacity: .6;
}

/* Animasi angka berubah */
.cd-number.tick { transform: scale(1.18); color: var(--gold); }

/* Countdown opened state */
.countdown-card.opened .cd-header {
    background: linear-gradient(145deg, #14532d, var(--accent-green));
}
.countdown-card.opened .cd-units { background: #f0fdf6; }
.countdown-card.opened .cd-unit  { background: var(--accent-green); }

/* ============================================================
   FORM LOCKED OVERLAY
   ============================================================ */
.login-card { position: relative; }
.form-locked-overlay {
    position: absolute;
    inset: 0;
    top: 90px;           /* below card-header-inner */
    background: rgba(246,247,251,.85);
    backdrop-filter: blur(3px);
    -webkit-backdrop-filter: blur(3px);
    z-index: 10;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 0 0 var(--radius-lg) var(--radius-lg);
    transition: opacity .4s;
}
.form-locked-overlay.hidden {
    opacity: 0;
    pointer-events: none;
}
.locked-msg {
    text-align: center;
    display: flex; flex-direction: column; align-items: center; gap: 10px;
}
.locked-msg-icon { font-size: 32px; animation: lockedPulse 2s ease-in-out infinite; }
@keyframes lockedPulse { 0%,100%{transform:scale(1);opacity:1} 50%{transform:scale(1.1);opacity:.7} }
.locked-msg p {
    font-size: 13px; color: var(--gray-500);
    font-weight: 500; line-height: 1.5;
}

/* Disabled field tint */
.field-input:disabled  { opacity: .45; cursor: not-allowed; background: var(--gray-100); }
.btn-primary:disabled  { opacity: .55; cursor: not-allowed; background: var(--gray-400); box-shadow: none; }

/* ============================================================
   NOTICE
   ============================================================ */
.notice-card {
    display: flex; align-items: flex-start; gap: 10px;
    background: var(--gold-bg);
    border: 1px solid rgba(212,168,67,.35);
    border-left: 3px solid var(--gold);
    border-radius: var(--radius-md); padding: 13px 14px;
}
.notice-icon { font-size: 18px; flex-shrink: 0; margin-top: 1px; }
.notice-text { font-size: 13px; color: var(--gray-700); line-height: 1.6; }
.notice-text strong { color: var(--gray-900); font-weight: 600; }

/* ============================================================
   CARD
   ============================================================ */
.card {
    background: var(--white);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-md);
    border: 1px solid var(--gray-200);
    overflow: hidden;
}

.card-header-inner {
    background: linear-gradient(145deg, var(--green) 0%, var(--green-mid) 60%, var(--green-light) 100%);
    padding: 26px 20px 22px; text-align: center;
}
.card-icon  { font-size: 36px; display: block; margin-bottom: 10px; }
.card-title { font-family: var(--font-display); font-size: 20px; font-weight: 700; color: var(--white); margin-bottom: 6px; }
.card-desc  { font-size: 13px; color: rgba(255,255,255,.65); line-height: 1.5; }

/* Form inside card */
.login-card form { padding: 20px; display: flex; flex-direction: column; gap: 18px; }

.field-group { display:flex; flex-direction:column; gap:7px; }
.field-label { font-size:13px; font-weight:600; color:var(--gray-700); display:flex; align-items:center; gap:6px; }
.field-label-sub { font-weight:400; color:var(--gray-400); font-size:12px; }

.field-input {
    width: 100%; background: var(--gray-50);
    border: 1.5px solid var(--gray-200); border-radius: var(--radius-md);
    padding: 13px 14px; font-size: 15px; color: var(--gray-900);
    font-family: var(--font-body); outline: none; min-height: 50px;
    transition: border-color .2s, box-shadow .2s, background .2s;
}
.field-input::placeholder { color: var(--gray-400); font-size: 14px; }
.field-input:focus {
    border-color: var(--green-mid); background: var(--white);
    box-shadow: 0 0 0 3px rgba(14,77,47,.12);
}
.field-input.error { border-color: var(--accent-red); box-shadow: 0 0 0 3px rgba(220,38,38,.08); }

.field-password-wrap { position: relative; }
.field-password-wrap .field-input { padding-right: 50px; }

.btn-eye {
    position: absolute; right: 0; top: 0; height: 100%; width: 50px;
    background: none; border: none; color: var(--gray-400);
    display: flex; align-items: center; justify-content: center;
    transition: color .2s; -webkit-tap-highlight-color: transparent;
}
.btn-eye:hover { color: var(--green); }

.field-error {
    display: flex; align-items: center; gap: 8px;
    background: var(--red-bg); border: 1px solid var(--red-border);
    border-radius: var(--radius-sm); padding: 10px 13px;
    font-size: 13px; color: var(--accent-red);
    animation: slideDown .25s ease;
}
@keyframes slideDown { from{opacity:0;transform:translateY(-6px)} to{opacity:1;transform:translateY(0)} }

/* ============================================================
   BUTTONS
   ============================================================ */
.btn-primary {
    width: 100%;
    background: linear-gradient(135deg, var(--green) 0%, var(--green-mid) 100%);
    color: var(--white); border: none; border-radius: var(--radius-md);
    padding: 16px; font-size: 15px; font-weight: 700;
    box-shadow: 0 4px 16px rgba(14,77,47,.35);
    min-height: 52px; display: flex; align-items: center; justify-content: center; gap: 8px;
    transition: transform .15s, box-shadow .15s;
    -webkit-tap-highlight-color: transparent;
}
.btn-primary:hover  { box-shadow: 0 6px 22px rgba(14,77,47,.45); }
.btn-primary:active { transform: scale(.98); }
.btn-primary:disabled { opacity: .65; cursor: not-allowed; }

.btn-secondary {
    width: 100%; background: var(--white); color: var(--green);
    border: 1.5px solid var(--gray-200); border-radius: var(--radius-md);
    padding: 15px; font-size: 15px; font-weight: 600;
    min-height: 52px; display: flex; align-items: center; justify-content: center; gap: 8px;
    transition: background .15s, border-color .15s, transform .15s;
    -webkit-tap-highlight-color: transparent;
}
.btn-secondary:hover  { background: var(--green-pale); border-color: var(--green-mid); }
.btn-secondary:active { transform: scale(.98); }

.dot-pulse { display:flex; align-items:center; gap:5px; }
.dot-pulse span { width:6px; height:6px; background:rgba(255,255,255,.7); border-radius:50%; animation:dotBounce .9s ease-in-out infinite; }
.dot-pulse span:nth-child(2) { animation-delay:.15s; }
.dot-pulse span:nth-child(3) { animation-delay:.30s; }
@keyframes dotBounce { 0%,80%,100%{transform:translateY(0);opacity:.5} 40%{transform:translateY(-5px);opacity:1} }

/* ============================================================
   HELP & SECURITY
   ============================================================ */
.help-note { text-align:center; font-size:12.5px; color:var(--gray-500); line-height:1.6; padding:0 8px; }
.security-strip { display:flex; align-items:center; justify-content:center; gap:10px; flex-wrap:wrap; }
.sec-item { display:flex; align-items:center; gap:5px; font-size:12px; color:var(--gray-400); }
.sec-dot  { color:var(--gray-300); font-size:14px; }

/* ============================================================
   RESULT PAGE
   ============================================================ */
.page-result { display:flex; flex-direction:column; gap:16px; }

.confetti-wrap { position:fixed; inset:0; pointer-events:none; z-index:200; overflow:hidden; }
.confetti-piece { position:absolute; top:-12px; border-radius:3px; animation:cFall linear forwards; }
@keyframes cFall { 0%{transform:translateY(0) rotate(0deg);opacity:1} 90%{opacity:.7} 100%{transform:translateY(110vh) rotate(540deg);opacity:0} }

.status-hero {
    text-align:center; padding:28px 16px 24px;
    background:var(--white); border-radius:var(--radius-xl);
    border:1px solid var(--gray-200); box-shadow:var(--shadow-md);
}
.status-icon-ring {
    position:relative; width:84px; height:84px; border-radius:50%;
    background:var(--green-pale); border:2.5px solid rgba(22,163,74,.3);
    display:flex; align-items:center; justify-content:center;
    margin:0 auto 16px; font-size:38px;
    animation:popIn .5s cubic-bezier(.175,.885,.32,1.275) both;
}
.status-icon-ring.not-pass { background:var(--red-bg); border-color:rgba(220,38,38,.3); }
.ring-pulse {
    position:absolute; inset:-8px; border-radius:50%;
    border:2px solid rgba(22,163,74,.25);
    animation:ringPulse 2s ease-in-out infinite;
}
.not-pass .ring-pulse { border-color:rgba(220,38,38,.25); }
@keyframes ringPulse { 0%,100%{transform:scale(1);opacity:.8} 50%{transform:scale(1.12);opacity:.3} }
@keyframes popIn     { 0%{transform:scale(.3);opacity:0} 100%{transform:scale(1);opacity:1} }

.status-label-sm   { font-size:10px; font-weight:700; letter-spacing:.14em; text-transform:uppercase; color:var(--gray-400); margin-bottom:6px; }
.status-text       { font-family:var(--font-display); font-size:38px; font-weight:700; color:var(--accent-green); line-height:1; margin-bottom:10px; }
.status-text.not-pass { color:var(--accent-red); }
.status-school-stamp  { font-size:11.5px; color:var(--gray-400); }

.congrats-banner {
    background:linear-gradient(135deg, var(--gold-bg), #fffef5);
    border:1px solid rgba(212,168,67,.4); border-left:4px solid var(--gold);
    border-radius:var(--radius-md); padding:14px 16px;
    font-size:13.5px; color:var(--gray-700); line-height:1.6;
}
.congrats-banner strong { color:var(--accent-green); }

.data-card-title {
    display:flex; align-items:center; gap:7px; padding:13px 16px;
    font-size:12px; font-weight:700; letter-spacing:.08em; text-transform:uppercase;
    color:var(--gray-500); background:var(--gray-50); border-bottom:1px solid var(--gray-200);
}
.data-rows { display:flex; flex-direction:column; }
.data-row {
    display:grid; grid-template-columns:120px 1fr; gap:8px;
    padding:13px 16px; border-bottom:1px solid var(--gray-100); align-items:baseline;
}
.data-row:last-child { border-bottom:none; }
.data-key { font-size:12px; color:var(--gray-500); font-weight:500; }
.data-val { font-size:14px; color:var(--gray-900); font-weight:600; word-break:break-word; text-align:right; }

.result-actions { display:flex; flex-direction:column; gap:10px; }

/* ============================================================
   INFO CARD (Informasi Lebih Lanjut)
   ============================================================ */
.info-card-body {
    padding: 16px;
    display: flex;
    flex-direction: column;
    gap: 10px;
}
.info-paragraph {
    font-size: 13px;
    color: var(--gray-700);
    line-height: 1.7;
}
.info-paragraph strong { color: var(--green); }

.contact-box {
    background: var(--green-pale);
    border: 1px solid rgba(14,77,47,.18);
    border-radius: var(--radius-md);
    padding: 13px 14px;
    display: flex;
    flex-direction: column;
    gap: 10px;
    margin-top: 4px;
}
.contact-label {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 11.5px;
    font-weight: 700;
    letter-spacing: .06em;
    text-transform: uppercase;
    color: var(--green-mid);
}
.contact-wa {
    display: flex;
    align-items: center;
    gap: 10px;
    background: #25D366;
    color: #fff;
    text-decoration: none;
    font-size: 14px;
    font-weight: 700;
    padding: 11px 16px;
    border-radius: var(--radius-md);
    box-shadow: 0 3px 12px rgba(37,211,102,.35);
    transition: transform .15s, box-shadow .15s;
    -webkit-tap-highlight-color: transparent;
}
.contact-wa:hover  { box-shadow: 0 5px 18px rgba(37,211,102,.45); }
.contact-wa:active { transform: scale(.98); }
.contact-note {
    font-size: 10.5px;
    color: var(--gray-400);
    font-style: italic;
    text-align: center;
}

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer {
    background: var(--green); color: rgba(255,255,255,.6);
    text-align:center; padding:18px 16px; margin-top:auto;
}
.footer-school { font-size:13px; font-weight:700; color:var(--gold-light); margin-bottom:4px; }
.footer-copy   { font-size:11px; }

/* ============================================================
   MODAL HIMBAUAN
   ============================================================ */
.modal-overlay {
    position: fixed; inset: 0; z-index: 1000;
    background: rgba(0,0,0,.65);
    backdrop-filter: blur(4px); -webkit-backdrop-filter: blur(4px);
    display: flex; align-items: flex-start; justify-content: center;
    padding: clamp(10px, 3vw, 20px);
    opacity: 0; pointer-events: none;
    transition: opacity .3s ease;
    overflow-y: auto;
}
.modal-overlay.show { opacity: 1; pointer-events: auto; }
.modal-content {
    background: var(--white);
    width: 100%; max-width: 440px;
    border-radius: var(--radius-lg);
    padding: clamp(20px, 5vw, 30px) clamp(16px, 4vw, 24px);
    position: relative;
    text-align: center;
    transform: translateY(30px);
    transition: transform .3s cubic-bezier(0.175, 0.885, 0.32, 1.275);
    box-shadow: 0 15px 45px rgba(0,0,0,.3);
    margin: auto;
}
.modal-overlay.show .modal-content { transform: translateY(0); }
.modal-close {
    position: absolute; top: 10px; right: 12px;
    background: none; border: none; font-size: 28px;
    color: var(--gray-400); cursor: pointer;
    line-height: 1; padding: 8px; transition: color .2s;
    -webkit-tap-highlight-color: transparent;
}
.modal-close:hover { color: var(--gray-700); }
.modal-icon { font-size: clamp(36px, 10vw, 46px); margin-bottom: 12px; }
.modal-title { font-size: clamp(18px, 5vw, 20px); font-weight: 800; color: #b91c1c; margin-bottom: 14px; letter-spacing: -0.02em; }
.modal-body { font-size: clamp(13px, 3.5vw, 14px); color: var(--gray-700); text-align: left; line-height: 1.5; margin-bottom: 20px; }
.modal-list { 
    margin: 12px 0; background: #fef2f2; border: 1px solid #fecaca; 
    border-radius: var(--radius-sm); 
    padding: 12px 12px 12px clamp(24px, 6vw, 32px); 
    color: #991b1b; 
}
.modal-list li { margin-bottom: 6px; }
.modal-list li:last-child { margin-bottom: 0; }
.modal-content .btn-primary {
    white-space: normal; height: auto; padding: 14px; line-height: 1.4;
    font-size: clamp(13px, 4vw, 15px);
}

/* ============================================================
   PRINT
   ============================================================ */
.print-only-footer { display:none; }
@media print {
    body { background:white; }
    .site-header, .notice-card, .security-strip, .help-note,
    .result-actions, .confetti-wrap, .site-footer { display:none !important; }
    .main-wrap { max-width:100%; padding:12px; }
    .page-result { display:flex !important; }
    .status-text { color:#16a34a !important; }
    .card { box-shadow:none; border:1.5px solid #ddd; }
    .ring-pulse { display:none; }
    .print-only-footer {
        display:block !important; margin-top:24px; text-align:center;
        font-size:11px; color:#888; border-top:1px solid #ddd; padding-top:12px;
    }
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (min-width:480px) {
    .main-wrap        { padding:28px 24px 40px; }
    .school-name-main { font-size:17px; }
    .school-address   { font-size:10.5px; }
}
@media (min-width:640px) {
    .emblem-svg       { width:58px; height:58px; }
    .school-name-main { font-size:19px; }
}
