/* =========================================
   Daily Scratch-Off Plugin
   Version: 2.8.3
   ========================================= */

/* ===== FONTS ===== */
@import url('https://fonts.googleapis.com/css2?family=Nunito:wght@400;600;700;800;900&family=Bebas+Neue&display=swap');

/* ===== DESIGN TOKENS ===== */
:root {
  --primary:       #EB232D;
  --primary-dark:  #c41920;
  --primary-glow:  rgba(235,35,45,0.25);
  --success:       #16A34A;
  --success-light: #dcfce7;
  --danger:        #DC2626;
  --warning:       #D97706;
  --gold:          #F59E0B;
  --gray-50:  #F9FAFB; --gray-100: #F3F4F6; --gray-200: #E5E7EB;
  --gray-300: #D1D5DB; --gray-400: #9CA3AF; --gray-500: #6B7280;
  --gray-600: #4B5563; --gray-700: #374151; --gray-800: #1F2937; --gray-900: #111827;
  --sp-xs: 4px; --sp-sm: 8px; --sp-md: 12px; --sp-lg: 16px; --sp-xl: 20px; --sp-2xl: 24px;
  --font:    'Nunito', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  --display: 'Bebas Neue', 'Nunito', sans-serif;
  --sh-sm: 0 1px 3px 0 rgb(0 0 0/.10), 0 1px 2px -1px rgb(0 0 0/.10);
  --sh-md: 0 4px 6px -1px rgb(0 0 0/.10), 0 2px 4px -2px rgb(0 0 0/.10);
  --sh-lg: 0 10px 15px -3px rgb(0 0 0/.12), 0 4px 6px -4px rgb(0 0 0/.08);
  --sh-xl: 0 20px 25px -5px rgb(0 0 0/.12), 0 8px 10px -6px rgb(0 0 0/.08);
  --r-sm: 6px; --r-md: 10px; --r-lg: 16px; --r-xl: 22px; --r-full: 9999px;
  --tx-xs:   clamp(10px,2.5vw,12px); --tx-sm:   clamp(12px,3vw,14px);
  --tx-base: clamp(14px,3.5vw,16px); --tx-lg:   clamp(16px,4vw,18px);
  --tx-xl:   clamp(18px,4.5vw,20px); --tx-2xl:  clamp(20px,5vw,24px);
  --tx-3xl:  clamp(24px,6vw,30px);
}

/* ===== BASE ===== */
.dst-main-container,
.dst-main-container *,
.dst-main-container *::before,
.dst-main-container *::after { box-sizing: border-box; }
.dst-game-modal,
.dst-game-modal *,
.dst-game-modal *::before,
.dst-game-modal *::after,
.dst-winners-modal,
.dst-winners-modal *,
.dst-winners-modal *::before,
.dst-winners-modal *::after { box-sizing: border-box; }
.dst-main-container { display:block; font-family: var(--font); -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; position: relative; }
body.dst-no-scroll { overflow: hidden; height: 100vh; }

/* ===== COMPACT TRIGGER — Design 1: Split Banner ===== */
.dst-compact-button-wrapper {
    position:relative;
    border-radius:10px;
    overflow:hidden;
    max-width:100%;
    min-width:0;
    /* Ensure Elementor margins apply correctly */
    display:block;
    box-sizing:border-box;
}

.dst-compact-button {
    display:flex;
    align-items:center;
    gap:14px;
    background:linear-gradient(120deg,#5b7f9a 0%,#8bafc4 40%,#EB232D 100%);
    color:#fff;
    padding:18px 20px;
    border:0;
    cursor:pointer;
    position:relative;
    overflow:hidden;
    transition:filter .2s ease;
}
.dst-compact-button:hover { filter:brightness(1.06); }
.dst-compact-button::before {
    content:'';
    position:absolute;
    top:-60px; right:-60px;
    width:200px; height:200px;
    border-radius:50%;
    background:rgba(255,255,255,.08);
    pointer-events:none;
}
.dst-compact-button::after {
    content:'';
    position:absolute;
    top:0; left:-100%; bottom:0;
    width:60%;
    background:linear-gradient(90deg,transparent,rgba(255,255,255,.1),transparent);
    transition:left .6s ease;
    pointer-events:none;
}
.dst-compact-button:hover::after { left:100%; }
.dst-compact-button.has-unclaimed {
    background:linear-gradient(120deg,#5b7f9a 0%,#8bafc4 40%,#ff5f3f 100%);
}
.dst-compact-button.pulsing { animation:pulse 2s infinite; }

/* Icon */
.dst-button-icon {
    width:72px; height:72px;
    flex-shrink:0;
    filter:drop-shadow(0 3px 8px rgba(0,0,0,.45));
    margin-right:4px;
}
.dst-button-icon img { width:100%; height:100%; object-fit:contain; display:block; }

/* Center text stack */
.dst-button-mid { flex:1; min-width:0; }
.dst-button-pre {
    font-size:10px; font-weight:800; letter-spacing:3px;
    text-transform:uppercase; color:rgba(255,255,255,.45);
    margin-bottom:2px;
}
.dst-button-title {
    margin:0; font-size:clamp(15px,4.5vw,24px);
    font-family:var(--display); font-weight:400;
    letter-spacing:.06em; line-height:1.15; color:#fff;
    text-shadow:0 1px 4px rgba(0,0,0,.4);
    white-space:normal;
    word-break:break-word;
}
.dst-button-sub {
    margin:3px 0 0;
    font-size:var(--tx-sm); color:rgba(255,255,255,.7);
    font-weight:700; line-height:1.3;
}
.dst-button-balance {
    margin-top:4px;
    font-size:11px; font-weight:800;
    color:rgba(255,255,255,.5);
}
.dst-countdown-compact { font-weight:800; }

/* Right CTA pill */
.dst-button-cta {
    flex-shrink:0;
    background:#fff;
    color:#EB232D;
    border-radius:50px;
    padding:10px 18px;
    font-size:13px;
    font-weight:900;
    letter-spacing:.5px;
    white-space:nowrap;
    box-shadow:0 2px 8px rgba(0,0,0,.25);
    transition:transform .15s, box-shadow .15s;
}
.dst-compact-button:hover .dst-button-cta {
    transform:scale(1.05);
    box-shadow:0 4px 14px rgba(0,0,0,.3);
}
.dst-compact-button.has-unclaimed .dst-button-cta { color:#d43510; }

/* Winners strip below the card */
.dst-winners-strip {
    background:#4a6d85;
    color:rgba(255,255,255,.8);
    text-align:center;
    padding:8px;
    font-size:12px;
    font-weight:700;
    cursor:pointer;
    transition:background .15s, color .15s;
    letter-spacing:.5px;
}
.dst-winners-strip:hover { background:#3d5c71; color:#fff; }

/* ===== UNCLAIMED NOTICES ===== */
.dst-unclaimed-notice { background:linear-gradient(135deg,#ff5f3f 0%,#d43510 100%); border:2px solid rgba(255,255,255,.25); border-radius:var(--r-lg); padding:12px var(--sp-lg); margin-bottom:var(--sp-lg); text-align:center; font-weight:800; font-size:var(--tx-sm); color:#fff; box-shadow:0 4px 16px rgba(238,69,32,.35); animation:glow 2s infinite alternate; letter-spacing:.01em; }
.dst-unclaimed-success { background:linear-gradient(135deg,#16a34a,#15803d); border-radius:var(--r-xl); padding:28px var(--sp-2xl); text-align:center; color:#fff; box-shadow:0 8px 28px rgba(22,163,74,.3); animation:slideInUp .4s cubic-bezier(.34,1.56,.64,1); }

/* ===== MODALS ===== */
.dst-game-modal,.dst-winners-modal { position:fixed; top:0; left:0; right:0; bottom:0; z-index:10000; display:flex; align-items:center; justify-content:center; padding:var(--sp-lg); }
.dst-modal-overlay { position:absolute; top:0; left:0; right:0; bottom:0; background:rgba(0,0,0,.75); z-index:1; }
.dst-modal-content { position:relative; z-index:2; background:#fff; border-radius:var(--r-xl); width:100%; max-width:500px; max-height:90vh; display:flex; flex-direction:column; overflow:hidden; box-shadow:0 25px 50px -12px rgba(0,0,0,.35); animation:modalZoom .22s ease; }
.dst-game-modal .dst-modal-content { max-width:550px; }
.dst-modal-header { padding:var(--sp-lg) var(--sp-xl); border-bottom:1px solid var(--gray-100); display:flex; align-items:center; justify-content:space-between; flex-shrink:0; background:linear-gradient(135deg,var(--primary) 0%,var(--primary-dark) 100%); }
.dst-modal-header h2 { margin:0; font-size:clamp(22px,5.5vw,28px); color:#fff; font-family:var(--display); font-weight:400; letter-spacing:.06em; text-shadow:0 1px 3px rgba(0,0,0,.25); }
.dst-close-button { background:rgba(255,255,255,.2); color:#fff; width:32px; height:32px; border-radius:50%; border:1px solid rgba(255,255,255,.35); cursor:pointer; display:flex; align-items:center; justify-content:center; font-size:14px; font-weight:700; transition:all .2s ease; flex-shrink:0; backdrop-filter:blur(4px); }
.dst-close-button:hover { background:rgba(255,255,255,.35); transform:scale(1.1); }
.dst-game-content,.dst-winners-content { flex:1; overflow-y:auto; overflow-x:hidden; }
.dst-game-content::-webkit-scrollbar,.dst-winners-content::-webkit-scrollbar { width:6px; }
.dst-game-content::-webkit-scrollbar-track,.dst-winners-content::-webkit-scrollbar-track { background:#f1f1f1; }
.dst-game-content::-webkit-scrollbar-thumb,.dst-winners-content::-webkit-scrollbar-thumb { background:#888; border-radius:3px; }

/* ===== TICKET CARD ===== */
.dst-ticket-card { padding:var(--sp-lg); background:var(--gray-50); }
.dst-ticket { background:linear-gradient(145deg,var(--primary) 0%,#b01820 50%,var(--primary-dark) 100%); border-radius:var(--r-md); padding:var(--sp-lg); box-shadow:var(--sh-lg),inset 0 1px 0 rgba(255,255,255,.15); position:relative; overflow:hidden; border:1px solid rgba(255,255,255,.1); }
.dst-ticket::before { content:''; position:absolute; top:-50%; left:-50%; width:200%; height:200%; background:radial-gradient(circle at 30% 30%,rgba(255,255,255,.12) 0%,transparent 60%); animation:shimmer 4s infinite; pointer-events:none; }
.dst-ticket-header { text-align:center; color:#fff; position:relative; z-index:2; }
.dst-logo { font-size:clamp(22px,6vw,30px); font-family:var(--display); font-weight:400; letter-spacing:.12em; margin-bottom:var(--sp-xs); text-shadow:0 2px 6px rgba(0,0,0,.3); }
.dst-subtitle { font-size:clamp(15px,4vw,19px); font-weight:800; opacity:1; letter-spacing:.06em; color:#fff; text-shadow:0 1px 4px rgba(0,0,0,.3); }
.dst-ticket-footer { text-align:center; font-weight:700; font-size:var(--tx-xs); margin-top:var(--sp-md); color:rgba(255,255,255,.7); font-family:var(--font); letter-spacing:.03em; }
.dst-win-condition { margin-bottom:var(--sp-xs); }
.dst-serial { opacity:.5; font-size:10px; letter-spacing:.06em; }

/* ===== SCRATCH INSTRUCTION ===== */
.dst-scratch-instruction { text-align:center; font-weight:800; color:var(--gray-800); font-size:var(--tx-sm); background:rgba(255,255,255,.97); padding:var(--sp-sm) var(--sp-md); border-radius:var(--r-sm); border:2px solid rgba(255,255,255,.6); box-shadow:var(--sh-md); margin-bottom:var(--sp-md); font-family:var(--font); white-space:nowrap; letter-spacing:.01em; }
.dst-scratch-instruction.ready { border-color:var(--success); background:var(--success-light); color:var(--success); animation:pulseGlow 1.5s infinite; }

/* ===== SCRATCH AREA ===== */
.dst-scratch-area { background:rgba(255,255,255,.95); border-radius:var(--r-md); margin:var(--sp-lg) 0; position:relative; overflow:hidden; display:flex; justify-content:center; align-items:center; padding:10px; }
.dst-full-scratch-container { position:relative; width:100%; min-height:240px; }
.dst-scratch-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:var(--sp-sm); width:100%; max-width:320px; margin:var(--sp-lg) auto; position:relative; z-index:1; }
.dst-scratch-cell { position:relative; aspect-ratio:1; border-radius:var(--r-sm); overflow:hidden; background:var(--gray-100); border:2px solid #fff; box-shadow:var(--sh-sm); }
.dst-prize-reveal { position:relative; z-index:1; display:flex; align-items:center; justify-content:center; height:100%; width:100%; pointer-events:none; background:linear-gradient(135deg,#fff 0%,#f8f9fa 100%); }
.dst-symbol { font-size:clamp(24px,8vw,48px); line-height:1; }

/* ===== SCRATCH CANVAS COVER ===== */
/* Background is transparent — canvas draws the silver; destination-out reveals grid below */
.dst-full-scratch-cover { position:absolute !important; top:0 !important; left:0 !important; right:0 !important; bottom:0 !important; z-index:10 !important; background:transparent !important; cursor:crosshair !important; }
.dst-scratch-canvas { position:absolute !important; top:0 !important; left:0 !important; width:100% !important; height:100% !important; z-index:2 !important; touch-action:none !important; cursor:crosshair !important; }

/* ===== BUTTONS ===== */
.dst-scratch-button { width:100%; background:linear-gradient(135deg,var(--success) 0%,#15803d 100%); color:#fff; border:0; padding:var(--sp-md) var(--sp-lg); border-radius:var(--r-md); font-family:var(--display); font-weight:400; letter-spacing:.08em; font-size:clamp(18px,4.5vw,22px); cursor:pointer; transition:all .25s cubic-bezier(.34,1.56,.64,1); box-shadow:0 4px 14px rgba(22,163,74,.35),0 2px 4px rgba(0,0,0,.12); margin:var(--sp-lg) 0; white-space:nowrap; text-shadow:0 1px 2px rgba(0,0,0,.2); }
.dst-scratch-button:hover:not(:disabled) { transform:translateY(-2px) scale(1.02); box-shadow:0 8px 24px rgba(22,163,74,.45),0 4px 8px rgba(0,0,0,.15); }
.dst-scratch-button:disabled { opacity:.6; cursor:not-allowed; transform:none; }
.dst-scratch-button.has-unclaimed { background:linear-gradient(135deg,#ff5f3f 0%,#d43510 100%); box-shadow:0 4px 14px rgba(238,69,32,.4),0 2px 4px rgba(0,0,0,.12); }

/* ===== COOLDOWN ===== */
.dst-cooldown-card { background:linear-gradient(135deg,var(--gray-100) 0%,var(--gray-200) 100%); border-radius:var(--r-lg); padding:var(--sp-2xl) var(--sp-lg); text-align:center; position:relative; }
.dst-cooldown-header { position:absolute; top:-12px; left:50%; transform:translateX(-50%); background:var(--gray-700); color:#fff; padding:var(--sp-xs) var(--sp-md); border-radius:var(--r-full); font-family:var(--display); font-weight:700; font-size:var(--tx-xs); white-space:nowrap; }
.dst-countdown { font-family:var(--display); font-weight:800; font-size:var(--tx-xl); color:var(--primary); margin:var(--sp-md) 0; }

/* ===== PRIZE RESULT ===== */
.dst-prize-result { position:relative; display:flex; flex-direction:column; align-items:center; justify-content:center; width:95%; max-width:400px; margin:0 auto; background:linear-gradient(135deg,#fffef7 0%,#fff9e6 100%); border-radius:var(--r-xl); padding:var(--sp-xl); box-shadow:var(--sh-xl),0 0 0 1px rgba(245,158,11,.2); text-align:center; border:3px solid var(--gold); }
.dst-prize-result.try-again { border-color:var(--gray-300); background:linear-gradient(135deg,#fafafa 0%,#f3f4f6 100%); box-shadow:var(--sh-xl),0 0 0 1px rgba(209,213,219,.4); }
.dst-prize-result h3 { margin:0 0 var(--sp-md); font-family:var(--display); font-weight:400; letter-spacing:.08em; font-size:clamp(26px,6.5vw,34px); color:var(--gray-900); line-height:1; }
.dst-prize-text { font-size:var(--tx-base); color:var(--gray-600); margin:0 0 var(--sp-lg); line-height:1.5; word-wrap:break-word; hyphens:auto; font-weight:600; }

/* ===== CLAIM BUTTON ===== */
.dst-claim-button { width:100%; max-width:300px; margin:0 auto var(--sp-md); background:linear-gradient(135deg,#F59E0B 0%,#D97706 100%); color:#fff; border:0; padding:var(--sp-md) var(--sp-lg); border-radius:var(--r-md); font-family:var(--display); font-weight:400; letter-spacing:.08em; font-size:clamp(18px,4.5vw,22px); text-align:center; cursor:pointer; transition:all .25s cubic-bezier(.34,1.56,.64,1); box-shadow:0 4px 14px rgba(217,119,6,.35),0 2px 4px rgba(0,0,0,.12); line-height:1.3; text-shadow:0 1px 2px rgba(0,0,0,.15); }
.dst-claim-button:hover:not(:disabled) { transform:scale(1.03); box-shadow:0 8px 24px rgba(217,119,6,.45),0 4px 8px rgba(0,0,0,.15); }
.dst-claim-button:disabled { opacity:.65; cursor:not-allowed; transform:none; }
.dst-claim-button.dst-claimed { background:linear-gradient(135deg,var(--success) 0%,#15803d 100%); box-shadow:0 4px 14px rgba(22,163,74,.35); animation:claimSuccess .6s ease; }
.dst-claim-main { font-size:var(--tx-sm); font-weight:700; margin-bottom:var(--sp-xs); line-height:1.2; font-family:var(--font); letter-spacing:0; }
.dst-claim-sub { font-size:var(--tx-xs); font-weight:600; opacity:.88; line-height:1.2; font-family:var(--font); letter-spacing:0; }
.dst-countdown-number { display:inline-block; min-width:24px; padding:2px 6px; background:rgba(255,255,255,.25); border-radius:4px; font-weight:800; font-size:var(--tx-base); color:#fff; text-shadow:0 1px 3px rgba(0,0,0,.4); }
.dst-countdown-number.dst-urgent { animation:urgentPulse .5s infinite; }
.dst-pulse-urgent { animation:btnPulse .5s infinite; background:linear-gradient(45deg,#ef4444,#dc2626) !important; }
.dst-claiming { font-size:var(--tx-sm); font-weight:600; line-height:1.3; font-family:var(--font); letter-spacing:0; }

/* ===== DOGBONES ANIMATION ===== */
.dst-bones-reward { margin:var(--sp-lg) 0; }
.dst-bones-animation { display:flex; flex-direction:column; align-items:center; justify-content:center; gap:var(--sp-xs); }
.dst-bones-animate .dst-bones-icon { animation:boneSpin 1s ease infinite; }
.dst-bones-plus { color:var(--success); font-weight:900; font-size:1.2em; }
.dst-bones-earned { color:var(--primary); font-weight:900; font-family:var(--display); white-space:nowrap; letter-spacing:.04em; font-size:1.1em; }
.dst-bones-first-line { display:flex; align-items:center; justify-content:center; gap:var(--sp-sm); font-size:clamp(24px,6vw,32px); }
.dst-bones-tagline { font-size:var(--tx-sm); font-weight:600; color:var(--gray-700); text-align:center; margin-top:var(--sp-xs); }

/* ===== WINNERS LIST — Option D Newspaper Ticker ===== */
.dst-winners-card { padding:0; }
.dst-winners-list-head { padding:12px 18px 10px; font-size:10px; font-weight:800; letter-spacing:3px; text-transform:uppercase; color:#bbb; border-bottom:1px solid #eee; background:#fff; }
.dst-winners-list { list-style:none; padding:0; margin:0; }
.dst-winner-row { display:flex; align-items:center; gap:12px; padding:13px 18px; border-bottom:1px solid #f0f0f0; background:#fff; transition:background .15s; }
.dst-winner-row:nth-child(even) { background:#f9f9f9; }
.dst-winner-row:hover { background:#fff3f3; }
.dst-winner-sym { font-size:30px; flex-shrink:0; width:40px; text-align:center; line-height:1; }
.dst-winner-mid { flex:1; min-width:0; }
.dst-winner-name { font-size:17px; font-weight:800; color:#1a1a1a; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.dst-winner-sub { font-size:12px; color:#999; margin-top:2px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.dst-winner-right { text-align:right; flex-shrink:0; }
.dst-winner-amt { font-size:22px; font-weight:900; color:var(--primary); font-variant-numeric:tabular-nums; line-height:1; }
.dst-winner-unit { font-size:10px; color:#ccc; font-weight:600; text-transform:uppercase; letter-spacing:.5px; margin-top:2px; }
.dst-no-winners { text-align:center; padding:var(--sp-2xl); color:var(--gray-500); font-style:italic; font-size:var(--tx-sm); }

/* ===== POP EFFECTS ===== */
.dst-pop { animation:pop .4s ease-out; }
.dst-pop.win  { color:var(--success); }
.dst-pop.lose { color:var(--danger);  }

/* ===== UTILITY ===== */
.dst-test-mode-notice { background:linear-gradient(135deg,var(--warning) 0%,#DC2626 100%); color:#fff; padding:var(--sp-sm) var(--sp-md); border-radius:var(--r-full); font-family:var(--display); font-weight:700; font-size:var(--tx-xs); text-align:center; margin:var(--sp-md) 0; white-space:nowrap; }
.dst-login-prompt { background:#fff; border-radius:var(--r-lg); padding:var(--sp-2xl); text-align:center; box-shadow:var(--sh-lg); margin:var(--sp-lg); max-width:400px; margin-left:auto; margin-right:auto; }
.dst-login-prompt h3 { margin:0 0 var(--sp-md); font-family:var(--display); font-weight:400; font-size:var(--tx-2xl); color:var(--gray-900); letter-spacing:.08em; }
.dst-login-prompt a { color:var(--primary); font-weight:700; text-decoration:none; border-bottom:2px solid transparent; transition:border-color .2s; }
.dst-login-prompt a:hover { border-bottom-color:var(--primary); }

/* ===== ADMIN ===== */
.mycard { position:relative; margin-top:20px; padding:.7em 2em 1em; border:1px solid #c3c4c7; box-shadow:0 1px 1px rgba(0,0,0,.04); background:#fff; }
.stats-grid,.prize-stats-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(200px,1fr)); gap:12px; }
.test-mode-card { border-left:4px solid var(--warning); }
.test-mode-active { background:#fff8e1; border:1px solid #ffe08a; padding:8px 12px; border-radius:6px; }
.table-wrapper { overflow:auto; }
.expected-value { display:inline-block; padding:3px 8px; background:#f0f0f1; border-radius:3px; }

/* ===== KEYFRAMES ===== */
@keyframes shimmer    { 0%,100%{transform:rotate(0deg)} 50%{transform:rotate(180deg)} }
@keyframes pulseGlow  { 0%,100%{opacity:1;box-shadow:0 0 8px rgba(22,163,74,.4)} 50%{opacity:.85;box-shadow:0 0 12px rgba(22,163,74,.6)} }
@keyframes pop        { 0%{transform:scale(.8);opacity:.6} 60%{transform:scale(1.2);opacity:1} 100%{transform:scale(1);opacity:1} }
@keyframes claimSuccess{ 0%{transform:scale(1)} 50%{transform:scale(1.05)rotate(2deg)} 100%{transform:scale(1)rotate(0)} }
@keyframes boneSpin   { 0%,100%{transform:rotate(0)scale(1)} 50%{transform:rotate(180deg)scale(1.2)} }
@keyframes modalZoom  { 0%{transform:scale(.92);opacity:0} 100%{transform:scale(1);opacity:1} }
@keyframes urgentPulse{ 0%,100%{transform:scale(1)} 50%{transform:scale(1.15)} }
@keyframes btnPulse   { 0%,100%{transform:scale(1);box-shadow:0 4px 12px rgba(255,215,0,.4)} 50%{transform:scale(1.02);box-shadow:0 6px 20px rgba(255,215,0,.6)} }
@keyframes glow       { from{box-shadow:0 5px 15px rgba(255,107,107,.3)} to{box-shadow:0 5px 25px rgba(255,107,107,.6)} }
@keyframes pulse      { 0%,100%{transform:scale(1);box-shadow:0 5px 15px rgba(255,107,107,.4)} 50%{transform:scale(1.05);box-shadow:0 8px 25px rgba(255,107,107,.8)} }
@keyframes slideInUp  { from{opacity:0;transform:translateY(30px)} to{opacity:1;transform:translateY(0)} }

/* ===== RESPONSIVE ===== */

/* Tiny phones */
@media (max-width: 360px) {
  .dst-compact-button { padding:12px 14px; gap:10px; }
  .dst-button-icon { width:52px; height:52px; }
  .dst-button-title { font-size:18px; }
  .dst-button-pre { display:none; }
  .dst-button-cta { padding:8px 12px; font-size:11px; }
  .dst-scratch-grid { gap:4px; }
  .dst-scratch-cell { min-height:70px; }
  .dst-symbol { font-size:clamp(18px,6vw,26px); }
  .dst-prize-text { font-size:var(--tx-sm); }
  .dst-claim-main { font-size:var(--tx-xs); }
  .dst-countdown-number { font-size:var(--tx-sm); min-width:20px; }
  .dst-modal-header h2 { font-size:16px; }
  .dst-logo { font-size:18px; }
  .dst-scratch-button { font-size:15px; padding:10px 12px; }
}

/* Mobile (phones) */
@media (max-width: 767px) {
  /* Banner card */
  .dst-compact-button { padding:12px 14px; gap:10px; }
  .dst-button-icon { width:52px; height:52px; margin-right:2px; }
  .dst-button-pre { font-size:9px; letter-spacing:2px; }
  .dst-button-sub { font-size:11px; }
  .dst-button-cta { padding:8px 12px; font-size:11px; letter-spacing:0; }
  .dst-winners-strip { font-size:11px; padding:7px; }

  /* Modal shell */
  .dst-game-modal,.dst-winners-modal { padding:8px; }
  .dst-modal-content { width:100%; max-height:96vh; border-radius:var(--r-md); }
  .dst-modal-header { padding:10px 14px; }
  .dst-modal-header h2 { font-size:clamp(17px,4.5vw,22px); }
  .dst-close-button { width:28px; height:28px; font-size:13px; }

  /* Ticket card interior */
  .dst-ticket-card { padding:10px; }
  .dst-ticket { padding:10px; }
  .dst-logo { font-size:clamp(18px,5.5vw,24px); letter-spacing:.08em; }
  .dst-subtitle { font-size:11px; }
  .dst-scratch-instruction { font-size:11px; padding:6px 10px; white-space:normal; }
  .dst-ticket-footer { font-size:10px; margin-top:8px; }

  /* Scratch grid */
  .dst-scratch-area { margin:8px 0; padding:6px; }
  .dst-scratch-grid { gap:5px; margin:8px auto; }
  .dst-scratch-cell { min-height:78px; }
  .dst-symbol { font-size:clamp(22px,6.5vw,34px); }

  /* Draw button */
  .dst-scratch-button { font-size:clamp(15px,4.5vw,18px); padding:10px 14px; margin:10px 0; }

  /* Prize result */
  .dst-prize-result { width:98%; padding:14px; border-radius:var(--r-lg); }
  .dst-prize-result h3 { font-size:clamp(22px,6vw,28px); }
  .dst-prize-text { font-size:var(--tx-sm); margin-bottom:10px; }
  .dst-claim-button { font-size:clamp(15px,4.5vw,18px); padding:10px 14px; }
  .dst-bones-first-line { font-size:clamp(20px,5.5vw,26px); }

  /* Winners list */
  .dst-winners-card { padding:0; }
  .dst-winner-row { padding:10px 14px; gap:8px; }
  .dst-winner-sym { font-size:22px; width:30px; }
  .dst-winner-name { font-size:14px; }
  .dst-winner-sub { font-size:11px; }
  .dst-winner-amt { font-size:16px; }
}

/* Tablet */
@media (min-width: 768px) and (max-width: 1023px) {
  .dst-scratch-grid { max-width:320px; }
  .dst-symbol { font-size:clamp(40px,6vw,56px); }
}

/* Desktop */
@media (min-width: 1024px) {
  .dst-scratch-grid { max-width:360px; }
}
@media (prefers-reduced-motion: reduce) {
  *,*::before,*::after { animation-duration:.01ms !important; animation-iteration-count:1 !important; transition-duration:.01ms !important; }
}
@media (prefers-contrast: high) {
  .dst-compact-button { border:2px solid currentColor; }
  .dst-prize-result { border-width:3px; }
}
@media print { .dst-main-container { display:none; } }
