:root{
  --bg-gradient: linear-gradient(135deg, #f5f7fa 0%, #c3cfe2 100%);
  --card-cover-bg: linear-gradient(135deg, #bb1b3b 0%, #764ba2 100%);
  --card-bottom-bg: #ffffff;
  --text-main: #333;
  --text-light: #fff;
  --accent: #2d023b;
  --muted: #2a0c32;
  
  /* Dimensions for the card */
  --card-width: 300px;
  --card-height: 420px;
}

*{box-sizing:border-box;-webkit-tap-highlight-color: transparent;-webkit-user-select: none;user-select: none;}
body{margin:0;font-family:'Inter',system-ui,sans-serif;background:var(--bg-gradient);color:var(--text-main);height:100vh;overflow:hidden;display:flex;flex-direction:column;overflow-y:auto;background-attachment:fixed;background:#1d032a}
body::before{content:"";width:100%;aspect-ratio:2;position:absolute;left:0;top:0;background:url(../images/hidden-spy-bg-01.jpg) center bottom / cover;z-index:-1}
.logo{width:100px;}
.app-root{width:100%;height:100%;max-width:600px;margin:0 auto;padding:1rem;display:flex;flex-direction:column;position:relative}
.screen{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;transition:opacity .4s ease;}
.hidden{display:none!important}
h1{margin-bottom: -20px;color: var(--text-light);font-size:2.5rem;font-size: 60px;color: #b52c47;}
h2{color:var(--text-light)}
.controls{background: #bb1b3b;padding:20px;border-radius:20px;box-shadow:0 10px 30px #0000001a;width:100%;overflow-y:auto;background-image: linear-gradient(135deg,rgba(255,255,255, .1) , rgba(0,0,0, .3));box-shadow: 0 0 30px black;}
.controls label{display:block;margin:10px 0 5px;font-weight:700;color:var(--muted)}
select,input{width:100%;padding:12px;border-radius:10px;border: none;background: var(--muted);background-image: linear-gradient(135deg,rgba(255,255,255, .1) , rgba(0,0,0, .3));margin-bottom:10px;color: white;}
.category-list{display:flex;gap:10px;flex-wrap:wrap;justify-content:center}
.cat-item{padding:10px 15px;border-radius:12px;background: var(--muted);border:2px solid transparent;cursor:pointer;box-shadow:0 4px 6px #0000000d;transition:transform 0.2s,border-color .2s;display:flex;align-items:center;gap:8px;color: #e9206a;border: 2px solid;}
.cat-item:hover{transform:translateY(-2px)}
.cat-item.selected{border-color: white;color: white;}
#btn-start{width:100%;height:55px;font-size:1.2rem;font-weight:700;margin: 50px auto 20px;max-width: 300px;}
#btn-random{width:auto;align-self:center;font-size:.85rem;padding:6px 15px;order:2;opacity:.8}
.buttons{display:flex;flex-direction:column;gap:15px;margin-top:20px}
button{padding:14px 24px;border:none;border-radius:50px;font-size:1rem;font-weight:700;cursor:pointer;transition:transform 0.1s,box-shadow .2s}
.btn-primary{background: var(--card-cover-bg);color:#fff;box-shadow:0 4px 15px #764ba266;flex:1}
.btn-primary:active{transform:scale(0.98)}
.btn-secondary{background: #fff;color:var(--accent);border:2px solid var(--accent)}
.card-area{position:relative;width:var(--card-width);height:var(--card-height);margin:20px 0;perspective:1000px}
.card-wrapper{position:relative;width:100%;height:100%}
.card{position:absolute;top:0;left:0;width:100%;height:100%;border-radius:24px;display:flex;flex-direction:column;align-items:center;justify-content:center;font-size:2rem;font-weight:800;text-align:center;user-select:none;will-change:transform;-webkit-user-drag:none}
.card-bottom{background:var(--card-bottom-bg);color:#333;z-index:1;border:1px solid #eee;box-shadow:inset 0 0 20px #0000000d}
.reveal-hint{position:absolute;top:20px;font-size:.9rem;color:#bbb;font-weight:400;text-transform:uppercase;letter-spacing:1px}
.card-top{background-image:var(--card-cover-bg);color:#fff;z-index:2;cursor:grab;box-shadow:0 10px 30px #0003}
.card-top:active{cursor:grabbing}
.smooth-return{transition:transform .4s cubic-bezier(0.175,0.885,0.32,1.275)}
#player-info{font-size:1.5rem;font-weight:700;color: var(--text-light);margin-bottom:10px;text-align: center;}
#player-inputs{max-height:none!important;overflow:visible!important}
.end-summary{width:100%;text-align:left}
.end-player{padding:10px;background: #bb1b3b;margin-bottom:8px;border-radius:8px;display:flex;justify-content:space-between;color: var(--text-light);background-image: linear-gradient(135deg,rgba(255,255,255, .1) , rgba(0,0,0, .3));}
.end-player.spy{border-left:5px solid #ff6b6b}
.end-player.civilian{border-left:5px solid #4CAF50}
#timer-container{display:flex;flex-direction:column;align-items:center;justify-content:center;animation:zoomIn .5s ease;background: rgba(255,255,255, .8);padding: 20px;border-radius: 20px;}
@keyframes zoomIn{
from{opacity:0;transform:scale(0.8)}
to{opacity:1;transform:scale(1)}
}
svg{filter:drop-shadow(0 4px 10px #0000001a)}
.end-summary{display:flex;flex-direction:column;gap:12px;width:100%;margin-top:20px}
.reveal-box{background:#ffffffe6;padding:20px;border-radius:15px;box-shadow:0 4px 15px #0000001a;margin-bottom:20px;text-align:center}
.result-card{display:flex;justify-content:space-between;align-items:center;padding:15px 20px;border-radius:12px;background:#fff;box-shadow:0 2px 8px #0000000d;transition:transform .3s ease;border-left:6px solid #ccc}
.result-card.spy{border-left-color:#ff4757;background:#fff5f5;animation:pulseRed 2s infinite}
.result-card.civilian{border-left-color:#2ed573;background:#f1fcf5}
.role-tag{font-size:.8rem;font-weight:700;padding:4px 10px;border-radius:20px;text-transform:uppercase}
.spy .role-tag{background:#ff4757;color:#fff}
.civilian .role-tag{background:#2ed573;color:#fff}
@keyframes pulseRed{
0%{box-shadow:0 0 0 0 #ff475766}
70%{box-shadow:0 0 0 10px #ff475700}
100%{box-shadow:0 0 0 0 #ff475700}
}
footer{padding:10px;margin: -20px auto 20px;color: var(--text-light);opacity: .2;}

.bu{cursor:pointer;display:flex;color:#f05a7f;padding:5px 20px;font-size: 11px;border-radius:10px 0 0 10px;}
.bu .te{margin-right:10px;}

@media only screen and (max-width:820px){
h1{font-size: 38px;margin-bottom: -10px;}
}