/* ============================================================
   stil.css - foaia de stil GLOBALA pentru joci-cruce.ro
   Tema (variabile), reset, bara de derulare galbena, controale
   tematice (input, select+dropdown propriu, checkbox, toggle,
   buton, popup "?"). Se include in TOATE paginile; stilurile
   specifice fiecarei pagini raman in <style>-ul ei si pot
   suprascrie aici unde e nevoie.
   ============================================================ */

:root{
  --disp:"Sora","Segoe UI",sans-serif;
  --ui:"Inter","Segoe UI",sans-serif;
  --gold:#caa24f; --gold-2:#e0b85f;
  --ok:#5fd39a; --bad:#ee7d7d;
  --bg:#0d1117; --panel:rgba(15,20,28,.72); --line:#2c3442;
}
*{box-sizing:border-box;margin:0}
html{background:#0d1117}   /* fără alb în spatele barei de derulare */

/* ---- bara de derulare: pastilă aurie rotunjită (stil Telegram), fără alb, peste tot ---- */
*{scrollbar-color:var(--gold) transparent;scrollbar-width:thin}
::-webkit-scrollbar{width:12px;height:12px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--gold);border-radius:20px;border:3px solid transparent;background-clip:padding-box}
::-webkit-scrollbar-thumb:hover{background:var(--gold-2);border-width:2px}

/* ---- input number fara sageti albe urate ---- */
input[type=number]{-moz-appearance:textfield}
input[type=number]::-webkit-inner-spin-button,
input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}

/* ---- imaginile nu se trag ---- */
img{-webkit-user-drag:none}

/* ---- camp text de baza ---- */
.fld{background:rgba(255,255,255,.06);border:1px solid var(--line);border-radius:10px;
  padding:10px 13px;color:#eef2f5;font-size:16px;outline:none;font-family:var(--ui)}
.fld:focus{border-color:var(--gold)}
.fld.bad{border-color:var(--bad)}.fld.good{border-color:var(--ok)}

/* ---- textarea (la fel ca input; folosit la chat, comentarii) ---- */
textarea{font-family:var(--ui);resize:none;line-height:1.4}

/* ---- buton ---- */
.btn{font-family:var(--ui);font-weight:700;font-size:13px;border:none;border-radius:10px;
  padding:9px 16px;cursor:pointer;background:var(--gold);color:#221a08}
.btn:disabled{opacity:.45;cursor:not-allowed}
.btn.ghost{background:rgba(255,255,255,.06);color:#cdd5e0;border:1px solid #394250}
.btn.danger{background:rgba(238,125,125,.14);color:var(--bad);border:1px solid rgba(238,125,125,.4)}

/* ---- select nativ: optiuni inchise + sageata aurie (fallback fara JS) ---- */
select{color-scheme:dark;appearance:none;-webkit-appearance:none;cursor:pointer;padding-right:34px;
  background:rgba(255,255,255,.06) url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'><path d='M1 1l5 5 5-5' stroke='%23caa24f' stroke-width='2' fill='none' stroke-linecap='round' stroke-linejoin='round'/></svg>") no-repeat right 12px center}
select option{background:#161c26;color:#eef2f5}

/* ---- dropdown propriu (div) cu galben la hover/selectat ---- */
.cs{position:relative;min-width:190px;font-size:16px;user-select:none}
.cs-cur{background:rgba(255,255,255,.06);border:1px solid var(--line);border-radius:10px;padding:9px 34px 9px 12px;cursor:pointer;position:relative;color:#eef2f5}
.cs-cur::after{content:"";position:absolute;right:14px;top:50%;width:8px;height:8px;border-right:2px solid var(--gold);border-bottom:2px solid var(--gold);transform:translateY(-70%) rotate(45deg)}
.cs.open .cs-cur{border-color:var(--gold)}
.cs-list{position:absolute;left:0;right:0;top:calc(100% + 5px);background:#161c26;border:1px solid var(--line);border-radius:10px;max-height:300px;overflow-y:auto;z-index:50;box-shadow:0 14px 34px rgba(0,0,0,.55);display:none}
.cs.open .cs-list{display:block}
.cs.up .cs-list{top:auto;bottom:calc(100% + 5px)}   /* se deschide în SUS când jos nu e loc */
.cs-opt{padding:9px 13px;cursor:pointer;font-size:14.5px}
.cs-opt:hover{background:rgba(202,162,79,.2)}
.cs-opt.sel{background:var(--gold);color:#221a08;font-weight:700}

/* ---- toggle (comutator) ---- */
.sw{position:relative;width:46px;height:26px;flex:none;display:inline-block}
.sw input{position:absolute;opacity:0}
.sw label{position:absolute;inset:0;background:#39414f;border-radius:20px;cursor:pointer;transition:.2s;box-shadow:inset 0 0 0 1px rgba(255,255,255,.06)}
.sw label:before{content:"";position:absolute;top:3px;left:3px;width:20px;height:20px;background:#fff;border-radius:50%;transition:.2s}
.sw input:checked+label{background:var(--gold)}
.sw input:checked+label:before{transform:translateX(20px)}

/* ---- range (volum) ---- */
input[type=range]{accent-color:var(--gold)}

/* ---- ochi arată/ascunde parola (SVG, vizibil pe închis) ---- */
.pw-wrap{position:relative}
.pw-wrap input{padding-right:44px}
.pw-eye{position:absolute;right:8px;top:50%;transform:translateY(-50%);width:30px;height:30px;padding:0;border:none;cursor:pointer;opacity:.85;
  background-color:transparent;background-repeat:no-repeat;background-position:center;background-size:22px 22px}
.pw-eye:hover{opacity:1}
.pw-eye{background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23aab4c4' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><path d='M1 12s4-7 11-7 11 7 11 7-4 7-11 7S1 12 1 12z'/><circle cx='12' cy='12' r='3'/></svg>")}
.pw-eye.on{background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23caa24f' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><path d='M17.94 17.94A10.07 10.07 0 0 1 12 20c-7 0-11-8-11-8a18.45 18.45 0 0 1 5.06-5.94M9.9 4.24A9.12 9.12 0 0 1 12 4c7 0 11 8 11 8a18.5 18.5 0 0 1-2.16 3.19m-6.72-1.07a3 3 0 1 1-4.24-4.24'/><line x1='1' y1='1' x2='23' y2='23'/></svg>")}

/* ---- popup "?" cu detalii (designul nostru) ---- */
.help{display:inline-grid;place-items:center;width:18px;height:18px;border-radius:50%;border:1.5px solid var(--gold);color:var(--gold);font-size:11px;font-weight:800;cursor:pointer;position:relative;margin-left:7px;vertical-align:middle}
.help:hover{background:rgba(202,162,79,.16)}
.help .pop{display:none;position:absolute;left:-8px;top:calc(100% + 10px);width:248px;background:#161c26;border:1px solid var(--gold);border-radius:10px;padding:11px 13px;font-size:12.5px;font-weight:500;color:#dfe6ee;line-height:1.45;box-shadow:0 16px 42px rgba(0,0,0,.6);z-index:60;text-align:left;cursor:default;white-space:normal}
.help.open .pop{display:block}
.help .pop::before{content:"";position:absolute;left:12px;top:-6px;width:11px;height:11px;background:#161c26;border-left:1px solid var(--gold);border-top:1px solid var(--gold);transform:rotate(45deg)}

/* ---- checkbox custom (reutilizabil) ---- */
.chk{display:flex;align-items:flex-start;gap:9px;cursor:pointer;font-size:13px;color:#cdd5e0;line-height:1.45}
.chk input{appearance:none;-webkit-appearance:none;width:18px;height:18px;border:2px solid #4a5566;border-radius:5px;background:transparent;cursor:pointer;flex:none;position:relative;margin:1px 0 0}
.chk input:checked{background:var(--gold);border-color:var(--gold)}
.chk input:checked::after{content:"✓";position:absolute;inset:-2px;display:grid;place-items:center;color:#221a08;font-size:13px;font-weight:900}
.chk a{color:var(--gold);text-decoration:none}.chk a:hover{text-decoration:underline}

/* ---- modal lat: Termeni & GDPR ---- */
.tmodal{position:fixed;inset:0;background:rgba(0,0,0,.66);display:none;place-items:center;z-index:500;padding:18px}
.tmodal.open{display:grid}
.tmodal-card{width:min(780px,100%);max-height:88vh;display:flex;flex-direction:column;background:#11161e;border:1px solid #2c3442;border-radius:16px;box-shadow:0 30px 80px rgba(0,0,0,.6);overflow:hidden}
.tmodal-h{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:13px 16px;border-bottom:1px solid #232b38;flex-wrap:wrap}
.tmodal-h .tabs{display:flex;gap:8px;flex-wrap:wrap}
.tmodal-h .tabs button{font-family:var(--disp);font-weight:700;font-size:13px;border:1px solid #2c3442;background:rgba(255,255,255,.05);color:#aab4c4;border-radius:30px;padding:8px 15px;cursor:pointer}
.tmodal-h .tabs button.on{background:var(--gold);color:#221a08;border-color:var(--gold)}
.tmodal-h .x{color:#8a96a8;cursor:pointer;font-size:18px;padding:4px 9px;border-radius:8px}
.tmodal-h .x:hover{color:#fff;background:rgba(255,255,255,.08)}

/* ===== Popup tematic (jcAlert / jcConfirm) - înlocuiește alert()/confirm() default ===== */
.jc-ov{position:fixed;inset:0;background:rgba(6,9,14,.66);display:flex;align-items:center;justify-content:center;z-index:9999;padding:20px;opacity:0;transition:opacity .16s ease}
.jc-ov.show{opacity:1}
.jc-modal{width:min(390px,100%);background:#161c26;border:1px solid #2c3442;border-top:3px solid var(--gold);border-radius:16px;padding:22px 22px 18px;box-shadow:0 30px 80px rgba(0,0,0,.6);transform:translateY(8px) scale(.985);transition:transform .16s ease}
.jc-ov.show .jc-modal{transform:none}
.jc-modal .jc-ti{font-family:var(--disp);font-weight:800;font-size:17px;color:#eef2f5;margin-bottom:7px}
.jc-modal .jc-msg{font-size:14px;line-height:1.55;color:#cdd5e0;margin-bottom:18px;white-space:pre-line}
.jc-modal .jc-msg .jc-input{width:100%;background:rgba(255,255,255,.06);border:1px solid #2c3442;border-radius:10px;padding:10px 12px;color:#eef2f5;font-size:16px;outline:none;margin-top:10px}
.jc-modal .jc-msg .jc-input:focus{border-color:var(--gold)}
/* contor durată (zile / ore / minute) - tematic */
.jc-dur{display:flex;gap:9px;margin-top:14px}
.jc-durf{flex:1;display:flex;flex-direction:column;gap:5px}
.jc-durf label{font-size:10px;color:#9aa6b4;font-weight:700;text-transform:uppercase;letter-spacing:.05em;text-align:center}
.jc-step{display:flex;align-items:center;background:rgba(255,255,255,.05);border:1px solid #2c3442;border-radius:11px;overflow:hidden}
.jc-step:focus-within{border-color:var(--gold)}
.jc-step button{width:32px;height:42px;border:none;background:rgba(255,255,255,.04);color:#cdd5e0;font-size:20px;font-weight:700;cursor:pointer;flex:none;line-height:1}
.jc-step button:hover{background:rgba(202,162,79,.22);color:#f0d89a}
.jc-step input{flex:1;min-width:0;width:100%;background:none;border:none;color:#eef2f5;font-size:18px;font-weight:800;text-align:center;outline:none;padding:9px 0;-moz-appearance:textfield}
.jc-step input::-webkit-outer-spin-button,.jc-step input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}
.jc-hint{font-size:11.5px;color:#8a96a8;margin-top:9px;text-align:center}
.jc-lbl{display:block;font-size:12px;color:#cdd5e0;font-weight:600;margin:14px 0 6px}
.jc-modal .jc-acts{display:flex;gap:9px;justify-content:flex-end}
.jc-btn{border:none;border-radius:10px;padding:9px 18px;font-family:var(--ui);font-weight:700;font-size:14px;cursor:pointer}
.jc-btn.prim{background:var(--gold);color:#221a08}
.jc-btn.sec{background:rgba(255,255,255,.07);color:#cdd5e0;border:1px solid #394250}
.jc-btn.sec:hover{border-color:var(--gold);color:var(--gold)}
.jc-modal.err{border-top-color:#e0696b}
.jc-modal.err .jc-ti{color:#ffb3b3}

/* ===== Antet comun (jc_header) ===== */
.jc-head{display:flex;justify-content:space-between;align-items:center;padding:5px 18px;border-bottom:1px solid #1c2430;flex-wrap:nowrap;gap:10px;min-height:0}
.jc-head .jc-brand{font-family:var(--disp);font-weight:800;font-size:22px;color:var(--gold);text-decoration:none;display:inline-flex;align-items:center;flex:none}
.jc-head .jc-brand span{color:#eef2f5}
.jc-head .jc-brand img{height:54px;width:auto;display:block}
@media(max-width:560px){.jc-head .jc-brand img{height:44px}}
.jc-head .jc-menu{display:flex;gap:15px;align-items:center;flex-wrap:nowrap;overflow-x:auto;min-width:0;scrollbar-width:none}
.jc-head .jc-menu::-webkit-scrollbar{height:0}
.jc-head .jc-menu a{color:#aab4c4;text-decoration:none;font-weight:600;font-size:13.5px;white-space:nowrap}
.jc-head .jc-menu a:hover{color:var(--gold)}
.jc-head .jc-menu a.cta{color:var(--gold)}
.jc-head .jc-menu a.on{color:var(--gold)}
.jc-head .jc-pts{background:#1a2230;border:1px solid #26303d;border-radius:30px;padding:4px 12px;font-weight:700;font-size:12.5px;color:#cdd5e0;white-space:nowrap;flex:none}
.jc-head .jc-pts .v{font-family:var(--disp);font-weight:800;color:var(--g2,#f0d89a)}
/* container care centrează un card sub antet (pagini cu un singur card) */
.jc-center{flex:1;display:grid;place-items:center;padding:24px 16px;width:100%}

/* ===== Anti-zoom iOS: orice input/textarea/select are minim 16px pe telefon/tabletă =====
   (sub 16px, iPhone face zoom automat la focus). Global, deci acoperă toate paginile. */
@media(max-width:900px){
  input,textarea,select,.cs-cur{font-size:16px !important}
}
.tmodal-b{padding:18px 22px;overflow-y:auto;font-size:13.5px;line-height:1.6;color:#cdd5e0}
.tmodal-b h3{font-family:var(--disp);color:#f0d89a;font-size:16px;margin:16px 0 8px}.tmodal-b h3:first-child{margin-top:0}
.tmodal-b p{margin-bottom:10px}.tmodal-b ul{margin:0 0 10px 18px}.tmodal-b li{margin-bottom:5px}.tmodal-b b{color:#eef2f5}
.tmodal-b .warn{background:rgba(202,162,79,.08);border:1px solid rgba(202,162,79,.3);border-radius:10px;padding:10px 13px;margin:12px 0}
.tmodal-b section{display:none}.tmodal-b section.on{display:block}

/* ============================================================
   PC = layout "contained" (cum e definit in fiecare pagina).
   TELEFON / TABLETA (tactil) sau fereastra ingusta = 100% din ecran,
   nici mai mult, nici mai putin (fara margini laterale, fara overflow).
   ============================================================ */
@media (max-width: 760px), (pointer: coarse){
  html,body{overflow-x:hidden}
  body{padding-left:0 !important;padding-right:0 !important}
  .wrap,.card,.shell{width:100% !important;max-width:100% !important;border-radius:0 !important}
}

