* { box-sizing:border-box; }
:root {
  --brand-blue-deep:#04142b; --brand-blue-mid:#062b56; --brand-blue:#0b4d9c; --brand-blue-bright:#0d63d9; --brand-cyan:#22b4ff; --brand-yellow:#ffd34d; --brand-orange:#ff9c27; --muted:#7a8a9e; --error:#ff5f4e; --success:#39d079;
}
html,body { height:100%; }
body { margin:0; font-family: system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif; background:#020d1e; color:#e3eef8; }

/* HERO */
.info-hero { position:relative; padding:0; min-height:100vh; overflow:hidden; display:flex; align-items:stretch; background:#020d1e; }
.info-hero__bg { position:absolute; inset:0; background:radial-gradient(circle at 12% 25%, #083262 0%, #031b37 45%, #020d1e 80%); }
.info-hero__bg:after { content:""; position:absolute; inset:0; background:repeating-linear-gradient(75deg,rgba(255,255,255,.05) 0 2px, transparent 2px 7px), radial-gradient(circle at 75% 70%, rgba(13,99,217,.25), transparent 60%); mix-blend-mode:overlay; opacity:.55; }
.info-hero__overlay { position:absolute; inset:0; pointer-events:none; background:linear-gradient(to bottom right, rgba(255,255,255,.05), transparent 60%); }
.info-hero__content { position:relative; display:grid; grid-template-columns:repeat(auto-fit,minmax(360px,1fr)); gap:3.2rem; width:100%; max-width:1500px; margin:0 auto; padding:4.8rem clamp(1.2rem,2.4vw,3.4rem) 5.2rem; box-sizing:border-box; }
.info-hero__left { color:#f5f8fc; }
.promo-title { font-size:clamp(2.4rem,4.3vw,3.6rem); line-height:1.05; margin:0 0 1.05rem; background:linear-gradient(92deg,var(--brand-yellow) 10%, var(--brand-orange) 40%, #ffcf4d 70%, #fff 100%); -webkit-background-clip:text; background-clip:text; color:transparent; filter:drop-shadow(0 6px 22px rgba(255,168,32,.35)); letter-spacing:.5px; font-weight:800; }
.promo-sub { font-size:1.05rem; margin:0 0 1.9rem; color:#dce7f3; max-width:720px; font-weight:500; }
.steps { background:linear-gradient(145deg,rgba(10,47,96,.55),rgba(6,28,62,.75)); padding:1.45rem 1.55rem 1.55rem; border:1px solid rgba(255,255,255,.12); backdrop-filter:blur(10px) saturate(140%); border-radius:16px; position:relative; box-shadow:0 8px 28px -8px rgba(0,0,0,.6),0 3px 0 rgba(255,255,255,.07) inset; }
.steps:before { content:""; position:absolute; inset:0; border-radius:inherit; pointer-events:none; background:linear-gradient(120deg,rgba(255,211,77,.25),rgba(255,140,0,0) 40%); mix-blend-mode:overlay; }
.steps__title { margin:0 0 .85rem; font-size:1.05rem; letter-spacing:1px; font-weight:700; text-transform:uppercase; color:var(--brand-yellow); }
.steps__list { margin:0; padding-left:1.25rem; display:flex; flex-direction:column; gap:.6rem; font-size:.93rem; line-height:1.4; }
.steps__list li { position:relative; }
.note { font-size:.82rem; margin:1.5rem 0 1rem; color:#b9c9df; max-width:640px; }
.legal { font-size:.62rem; letter-spacing:1px; text-transform:uppercase; opacity:.7; margin:.2rem 0 0; color:#8aa1bc; font-weight:600; }
.info-hero__right { display:flex; align-items:flex-start; justify-content:center; flex-direction:column; position:relative; width:100%; max-width:480px; gap:.8rem; }
/* Hero image */
.hero-figure { margin:0 0 .8rem; position:relative; width:100%; display:flex; align-items:center; justify-content:center; padding:0; }
.hero-figure:before { content:""; position:absolute; inset:0; background:radial-gradient(circle at 50% 55%, rgba(34,180,255,.55), transparent 70%); filter:blur(55px); opacity:.55; }
.hero-figure__img { width:100%; max-width:520px; height:auto; display:block; position:relative; z-index:1; filter:drop-shadow(0 20px 38px rgba(0,0,0,.65)) drop-shadow(0 2px 4px rgba(0,0,0,.5)); animation:floatHero 9s ease-in-out infinite; border-radius:14px; }
@keyframes floatHero { 0%,100%{ transform:translateY(0);} 50%{ transform:translateY(-10px);} }
/* Search Card */
.search-card { width:100%; background:linear-gradient(160deg,rgba(8,50,105,.92),rgba(4,24,49,.95)); border-radius:16px; padding:1rem 1.1rem 1rem; position:relative; box-shadow:0 8px 20px -8px rgba(0,12,32,.5),0 3px 10px -3px rgba(0,16,38,.4); backdrop-filter:blur(14px) saturate(150%); border:1px solid rgba(255,255,255,.08); overflow:hidden; }
.search-card:before { content:""; position:absolute; inset:0; border-radius:inherit; padding:1px; background:linear-gradient(145deg,var(--brand-cyan),rgba(255,255,255,0) 60%); -webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0); mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0); -webkit-mask-composite:xor; mask-composite:exclude; opacity:.9; pointer-events:none; }
.search-card__title { margin:0 0 .3rem; font-size:1.05rem; font-weight:900; background:linear-gradient(90deg,var(--brand-yellow),var(--brand-orange)); -webkit-background-clip:text; background-clip:text; color:transparent; letter-spacing:.45px; filter:drop-shadow(0 2px 6px rgba(255,170,40,.3)); }
.search-card__desc { margin:0 0 .8rem; font-size:.7rem; color:#d5e2f3; line-height:1.25; }
.countdown-card { width:100%; background:linear-gradient(160deg,rgba(8,50,105,.92),rgba(4,24,49,.95)); border-radius:16px; padding:.75rem 1rem .75rem; position:relative; box-shadow:0 8px 20px -8px rgba(0,12,32,.5),0 3px 10px -3px rgba(0,16,38,.4); backdrop-filter:blur(14px) saturate(150%); border:1px solid rgba(255,255,255,.08); overflow:hidden; margin:0 0 .8rem; }
.countdown-card:before { content:""; position:absolute; inset:0; border-radius:inherit; padding:1px; background:linear-gradient(145deg,var(--brand-yellow),rgba(255,255,255,0) 60%); -webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0); mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0); -webkit-mask-composite:xor; mask-composite:exclude; opacity:.9; pointer-events:none; }
.countdown__title { font-weight:800; letter-spacing:.3px; margin:0 0 .4rem; color:#ffd34d; font-size:.85rem; text-align:center; }
.countdown__timer { display:flex; align-items:center; justify-content:center; gap:.4rem; color:#fff; }
.countdown__timer .time { background:rgba(255,255,255,.08); border:1px solid rgba(255,255,255,.15); border-radius:10px; padding:.35rem .45rem; min-width:52px; text-align:center; box-shadow:inset 0 2px 5px rgba(0,0,0,.2); }
.countdown__timer .time span { display:block; font-size:1.05rem; font-weight:900; letter-spacing:.3px; }
.countdown__timer .time small { font-size:.55rem; color:#cfe0f2; letter-spacing:.35px; }
.countdown__timer .sep { color:#89a9ce; font-weight:900; font-size:.8rem; }
.countdown__date { text-align:center; margin:.35rem 0 0; font-size:.65rem; color:#d5e2f3; }

/* Winners card */
.winners-card { width:100%; background:linear-gradient(160deg,rgba(8,50,105,.94),rgba(4,24,49,.96)); border-radius:16px; padding:.9rem 1rem 1rem; position:relative; box-shadow:0 8px 20px -8px rgba(0,12,32,.5),0 3px 10px -3px rgba(0,16,38,.4); backdrop-filter:blur(14px) saturate(155%); border:1px solid rgba(255,255,255,.11); overflow:hidden; margin:0 0 .8rem; }
.winners-card:before { content:""; position:absolute; inset:0; border-radius:inherit; padding:1px; background:linear-gradient(135deg,var(--brand-yellow) 0%,var(--brand-orange) 50%,rgba(255,255,255,0) 80%); -webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0); mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0); -webkit-mask-composite:xor; mask-composite:exclude; opacity:.92; pointer-events:none; }
.winners__header { margin:0 0 .6rem; text-align:center; }
.winners__title { font-size:1.1rem; font-weight:900; margin:0; background:linear-gradient(90deg,var(--brand-yellow),var(--brand-orange)); -webkit-background-clip:text; background-clip:text; color:transparent; letter-spacing:.5px; filter:drop-shadow(0 2px 6px rgba(255,170,40,.3)); }
.winners__subtitle { display:none; }
.winners__grid { display:grid; grid-template-columns:repeat(3,1fr); gap:.5rem; }
.winner-item { position:relative; overflow:hidden; border-radius:10px; background:rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.11); box-shadow:0 3px 10px rgba(0,0,0,.3); transition:transform .3s ease, box-shadow .3s ease; }
.winner-item:hover { transform:translateY(-2px); box-shadow:0 6px 16px rgba(0,0,0,.4); }
.winner-item--featured { grid-column:auto; }
.winner__figure { margin:0; position:relative; overflow:hidden; }
.winner__figure img { width:100%; height:auto; display:block; border-radius:10px; transition:transform .3s ease; }
.winner-item:hover .winner__figure img { transform:scale(1.02); }
.winner__caption { position:absolute; bottom:0; left:0; right:0; background:linear-gradient(to top,rgba(0,10,25,.92) 0%,rgba(0,10,25,.75) 50%,transparent 100%); padding:.4rem .6rem .35rem; color:#fff; font-weight:800; font-size:.65rem; letter-spacing:.4px; text-align:center; text-shadow:0 1px 4px rgba(0,0,0,.5); }
@media (min-width:600px){ .winners__grid { grid-template-columns:repeat(3,1fr); } }
@media (max-width:599px){ .winners__grid { grid-template-columns:1fr; gap:.6rem; } }

.search-field-group { display:flex; flex-direction:column; gap:.3rem; margin-bottom:.7rem; }
.search-field-group label { font-size:.58rem; letter-spacing:.95px; font-weight:700; text-transform:uppercase; color:#b7c7dc; }
.search-field-group input { border:1px solid rgba(255,255,255,.18); background:rgba(255,255,255,.08); padding:.6rem .8rem; border-radius:12px; font-size:.82rem; font-family:inherit; transition:border-color .25s, background .25s, box-shadow .25s, transform .25s; color:#fff; letter-spacing:.3px; }
.search-inline { display:flex; gap:.55rem; align-items:stretch; }
.search-inline select { background:rgba(255,255,255,.1); color:#fff; border:1px solid rgba(255,255,255,.18); border-radius:14px; font-size:.8rem; font-weight:600; letter-spacing:.5px; padding:.75rem .8rem; appearance:none; position:relative; cursor:pointer; min-width:92px; }
.search-inline select:focus { outline:none; border-color:var(--brand-cyan); box-shadow:0 0 0 3px rgba(34,180,255,.25); }
.search-inline input { flex:1; }
.search-field-group input::placeholder { color:#7e92aa; }
.search-field-group input:focus { outline:none; border-color:var(--brand-cyan); background:rgba(6,65,135,.45); box-shadow:0 0 0 3px rgba(34,180,255,.25), 0 4px 14px -4px rgba(0,0,0,.6); }
.btn { position:relative; cursor:pointer; border:none; background:linear-gradient(100deg,#0b55b4,#0d63d9,#1185ff); background-size:220% 100%; color:#fff; font-weight:700; letter-spacing:.6px; font-size:.88rem; padding:.95rem 1.25rem; border-radius:16px; display:inline-flex; align-items:center; justify-content:center; gap:.55rem; box-shadow:0 8px 22px -6px rgba(11,86,178,.55),0 3px 8px -2px rgba(0,0,0,.6); transition:background-position .6s, transform .25s, box-shadow .35s; width:auto; }
.btn--full { width:100%; }
.btn:hover { background-position:100% 0; box-shadow:0 10px 26px -8px rgba(11,86,178,.65),0 4px 10px -2px rgba(0,0,0,.55); }
.btn:active { transform:translateY(2px); box-shadow:0 5px 16px -6px rgba(0,0,0,.7); }
.btn__spinner { width:18px; height:18px; border-radius:50%; border:3px solid rgba(255,255,255,.55); border-top-color:var(--brand-cyan); animation:spin .8s linear infinite; }
.spinner.hidden { display:none !important; }
@keyframes spin { to { transform:rotate(360deg); } }
.search-hint { display:block; margin:.4rem 0 .35rem; font-size:.5rem; letter-spacing:.85px; text-transform:uppercase; font-weight:700; color:#6f869d; }
.search-msg { font-size:.78rem; min-height:1.2rem; font-weight:600; letter-spacing:.3px; }
.search-msg.error { color:var(--error); }
.search-msg.success { color:var(--success); }
.search-results { margin-top:1.25rem; font-size:.78rem; background:linear-gradient(160deg,#072b54,#051a34); color:#e3eef8; border-radius:18px; padding:1rem 1rem 1.15rem; max-height:360px; overflow:auto; box-shadow:0 10px 30px -12px rgba(0,0,0,.7) inset,0 2px 0 rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.08); }
.search-results table { width:100%; border-collapse:collapse; font-size:.75rem; }
.search-results th { text-align:left; font-weight:600; padding:.5rem .55rem; background:linear-gradient(90deg,rgba(13,99,217,.55),rgba(11,71,155,.55)); position:sticky; top:0; z-index:2; backdrop-filter:blur(3px); }
.search-results td { padding:.5rem .55rem; border-top:1px solid rgba(255,255,255,.09); }
.ticket-badge { display:inline-block; background:linear-gradient(90deg,var(--brand-yellow),var(--brand-orange)); color:#0b1729; padding:.28rem .6rem; border-radius:24px; font-size:.63rem; font-weight:800; letter-spacing:.7px; box-shadow:0 2px 6px -2px rgba(0,0,0,.55); }
.empty-row { text-align:center; opacity:.6; }
/* Field error highlight for CI mismatch */
.input-mismatch { outline:2px solid #ff5f4e !important; background:rgba(255,95,78,.1) !important; animation:shake .4s ease-in-out; }
@keyframes shake { 0%,100%{transform:translateX(0);} 25%{transform:translateX(-4px);} 50%{transform:translateX(4px);} 75%{transform:translateX(-2px);} }
/* Scrollbars */
.search-results::-webkit-scrollbar { width:10px; }
.search-results::-webkit-scrollbar-track { background:#061a30; border-radius:10px; }
.search-results::-webkit-scrollbar-thumb { background:linear-gradient(#0d63d9,#1185ff); border-radius:10px; }
/* Utility */
.hidden { display:none !important; }
/* Responsive hero */
@media (max-width:1100px){ .info-hero__content { gap:2.4rem; } .hero-figure__img { max-width:480px; } }
@media (max-width:900px){ .info-hero__content { padding:4.2rem 1.25rem 3.8rem; gap:2.3rem; } .search-card { max-width:520px; margin:0 auto; } .hero-figure { order:-1; } .promo-title { font-size:clamp(2.2rem,8vw,3.1rem); } }
@media (max-width:600px){ .promo-sub { font-size:.92rem; } .steps { padding:1rem .95rem 1.05rem; } .steps__list { font-size:.82rem; } .search-card { padding:1.7rem 1.2rem 1.9rem; } .promo-title { font-size:clamp(2rem,9vw,2.7rem); } .hero-figure__img { max-width:400px; } }
/* hero removido en esta versión; el fondo está dentro del panel izquierdo */

.container { width: 100%; max-width: none; margin: 0; padding: 0; }

.card { background:#fff; border-radius:12px; padding:1.25rem; box-shadow:0 8px 24px rgba(0,0,0,.1); border:1px solid #e5e7eb; }
.card h2 { margin-top:0; }
.card--error { border-color: #f8d7da; background:#fff5f5; }
.card--success { border-color: #d1fae5; background:#ecfdf5; }

.state { margin: 0 0 1rem; }
.hidden { display:none !important; }

.field { margin: .85rem 0; display:flex; flex-direction:column; gap:.35rem; }
.field label { font-weight:600; }
.field input[type="text"], .field input[type="tel"], .field input[type="file"], .field input[type="email"] {
  padding:1rem 1.2rem; border:1px solid #d1d5db; border-radius:30px; font-size:1.05rem;
}
.pill { border-radius:30px !important; }
.field input:focus { outline:2px solid var(--blue-2); outline-offset:2px; }
.hint { color: var(--muted); font-size:.85rem; }
.error { color: var(--error); font-size:.85rem; min-height:1.2em; }

.actions { margin-top: 1rem; }
.btn { display:inline-flex; align-items:center; gap:.5rem; background: var(--blue-2); color:#fff; border:none; padding:.75rem 1.1rem; border-radius:10px; font-weight:700; cursor:pointer; }
.btn:disabled { opacity:.6; cursor:not-allowed; }
.btn--secondary { background:#334155; }

.spinner { width:18px; height:18px; border-radius:50%; border:3px solid rgba(255,255,255,.35); border-top-color:#fff; animation:spin 1s linear infinite; }
.btn__spinner { border-color: rgba(255,255,255,.35); border-top-color:#fff; }
@keyframes spin { to { transform: rotate(360deg); } }

.footer { text-align:center; color:#6b7280; padding:2rem 1rem 3rem; display:none; }

/* Responsive */
@media (max-width: 480px) {
  .container { margin-top:-2rem; }
}

/* Two-column raffle layout */
.raffle-wrap { width:100%; display:grid; grid-template-columns: 1.1fr 14px 1fr; gap: 0; align-items: stretch; min-height: 100vh; background: linear-gradient(180deg, #0a4ea2, #0b70c9); border-radius: 0; overflow: hidden; box-shadow:none; }
.panel-left { position: relative; background: #0b3a88; }
/* Fondo de arte de campaña dentro del panel izquierdo */
.panel-left::before { content:""; position:absolute; inset:0; background: url('/assets/images/bolivianos/BOLIVIANOS_LANDING.png') center/cover no-repeat; filter:none; }
.left-overlay { position:absolute; inset:0; padding: 1rem; display:flex; flex-direction:column; justify-content:flex-end; gap: 1rem; background: linear-gradient(180deg, rgba(0,0,0,0) 0%, rgba(0,0,0,.35) 65%, rgba(0,0,0,.55) 100%); }

.divider { background: repeating-linear-gradient( to bottom, transparent 0 10px, rgba(255,255,255,.7) 10px 20px ); }

.ticket { color:#fff; }
.ticket label { display:block; font-weight:800; letter-spacing:.3px; margin-bottom:.35rem; }
.ticket-box { background:#fff; color:#0b3a88; border-radius: 16px; padding: .9rem 1rem; font-weight:800; font-size:1.05rem; }

.panel-right { background: transparent; padding: 1.25rem; color:#fff; }
.form-title { margin: .25rem 0 1rem; font-size: clamp(1.2rem, 2.5vw, 1.6rem); font-weight:900; text-transform: uppercase; }
.grid { display:grid; grid-template-columns: 1fr 1fr; gap: .9rem 1rem; }
.field--full { grid-column: 1 / -1; }

/* Make labels and inputs white-themed on right panel */
.panel-right label { color: #fff; font-weight:700; }
.panel-right .hint, .panel-right .error { color: #ffd7d7; }
.panel-right input { background: rgba(255,255,255,.96); color:#0f172a; border: none; box-shadow: 0 2px 6px rgba(0,0,0,.15); }

@media (max-width: 1024px) {
  .raffle-wrap { grid-template-columns: 1fr 12px 1fr; }
}

@media (max-width: 860px) {
  .raffle-wrap { grid-template-columns: 1fr; min-height: auto; }
  .divider { display:none; }
  .panel-left { min-height: 380px; }
  .panel-right { padding: clamp(12px, 3vw, 20px); }
  .grid { grid-template-columns: 1fr; }
}

@media (max-width: 480px) {
  .ticket-box { font-size: 1rem; }
  .form-title { font-size: 1.1rem; }
}

/* Success state polished UI */
#state-success { display:flex; justify-content:center; align-items:center; min-height: 60vh; }
.success { text-align:center; background: linear-gradient(180deg, #0ea5e9 0%, #0369a1 100%); color:#fff; padding: clamp(16px, 4vw, 28px); border-radius: 16px; box-shadow: 0 10px 30px rgba(0,0,0,.2); width:min(560px, 92%); }
.success__icon { display:inline-flex; width:58px; height:58px; border-radius:50%; background: rgba(255,255,255,.15); align-items:center; justify-content:center; margin: 4px auto 8px; animation: pop-in .4s ease-out; }
.success__title { margin:.25rem 0 .25rem; font-size: clamp(1.2rem, 3.2vw, 1.7rem); letter-spacing:.2px; }
.success__subtitle { margin: .25rem 0 .5rem; opacity:.9; }
.success__ticket { display:inline-block; margin:.35rem auto 1rem; background:#fff; color:#0b3a88; font-weight:800; letter-spacing: .5px; border-radius: 999px; padding: .6rem 1rem; min-width: 200px; box-shadow: 0 6px 16px rgba(0,0,0,.15); }
.success__actions { margin-top: .5rem; }

@keyframes pop-in {
  from { transform: scale(.85); opacity:0; }
  to { transform: scale(1); opacity:1; }
}

/* ===================== REGISTRO (TOKEN FORM) CARD ===================== */
.register-card { width:100%; background:linear-gradient(150deg,rgba(8,50,105,.96),rgba(4,24,49,.97)); border-radius:26px; padding:2.4rem 2.6rem 2.8rem; position:relative; box-shadow:0 14px 38px -12px rgba(0,16,38,.7),0 6px 18px -6px rgba(0,0,0,.55); backdrop-filter:blur(16px) saturate(160%); border:1px solid rgba(255,255,255,.08); overflow:hidden; }
.register-card:before { content:""; position:absolute; inset:0; border-radius:inherit; padding:1px; background:linear-gradient(135deg,var(--brand-yellow),rgba(255,255,255,0) 60%); -webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0); mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0); -webkit-mask-composite:xor; mask-composite:exclude; opacity:.85; pointer-events:none; }
.register-card__head { margin:0 0 1.4rem; }
.register-card__head .form-title { font-size:1.9rem; margin:0 0 .3rem; background:linear-gradient(90deg,var(--brand-yellow),var(--brand-orange)); -webkit-background-clip:text; background-clip:text; color:transparent; letter-spacing:.7px; font-weight:800; filter:drop-shadow(0 4px 14px rgba(255,170,40,.35)); }
.register-card__head .form-sub { margin:.2rem 0 0; font-size:.8rem; color:#c3d5e9; min-height:1.1rem; font-weight:600; letter-spacing:.3px; }

.register-card form .grid { display:grid; grid-template-columns:repeat(2,1fr); gap:1.05rem 1.2rem; }
@media (max-width:900px){ .register-card form .grid { grid-template-columns:1fr; } }

.register-card .field { margin:0; display:flex; flex-direction:column; gap:.45rem; }
.register-card .field label { font-size:.63rem; letter-spacing:1.15px; font-weight:700; text-transform:uppercase; color:#b7c7dc; }
.register-card .field input[type=text],
.register-card .field input[type=tel],
.register-card .field input[type=email],
.register-card .field input[type=file] { border:1px solid rgba(255,255,255,.18); background:rgba(255,255,255,.95); padding:.95rem 1.1rem; border-radius:38px; font-size:.92rem; font-weight:600; letter-spacing:.3px; font-family:inherit; color:#0f1e32; box-shadow:0 2px 4px rgba(0,0,0,.25) inset,0 2px 4px -1px rgba(0,0,0,.4); transition:border-color .25s, background .25s, box-shadow .25s; }
.register-card .field input[type=file] { padding:.55rem 1.1rem; font-size:.8rem; }
.register-card .field input:focus { outline:none; border-color:var(--brand-cyan); box-shadow:0 0 0 3px rgba(34,180,255,.25),0 2px 6px rgba(0,0,0,.55); background:#fff; }
.register-card .field input.input-mismatch { outline:2px solid var(--error); background:rgba(255,95,78,.1); }

/* Inline CI/CEX */
.register-card .inline { display:flex; gap:.55rem; align-items:stretch; }
.register-card .inline select { min-width:92px; border:1px solid rgba(255,255,255,.18); background:rgba(255,255,255,.95); border-radius:38px; padding:.95rem .9rem; font-weight:700; color:#0f1e32; }

.register-card .hint { color:#7e92aa; font-size:.62rem; letter-spacing:.8px; font-weight:600; margin:.1rem .9rem 0; }
.register-card .error { color:var(--error); font-size:.65rem; letter-spacing:.5px; font-weight:600; margin:.15rem .9rem 0; min-height:.9rem; }

.register-card .actions { margin-top:1.2rem; }
.register-card .btn { position:relative; cursor:pointer; border:none; background:linear-gradient(100deg,#0b55b4,#0d63d9,#1185ff); background-size:220% 100%; color:#fff; font-weight:800; letter-spacing:.8px; font-size:.95rem; padding:1.05rem 1.45rem; border-radius:38px; display:inline-flex; align-items:center; justify-content:center; gap:.6rem; box-shadow:0 10px 26px -8px rgba(11,86,178,.6),0 4px 10px -2px rgba(0,0,0,.6); transition:background-position .6s, transform .25s, box-shadow .35s; width:100%; }
.register-card .btn:hover:not(:disabled) { background-position:100% 0; box-shadow:0 12px 30px -10px rgba(11,86,178,.7),0 5px 14px -2px rgba(0,0,0,.55); transform:translateY(-2px); }
.register-card .btn:active:not(:disabled) { transform:translateY(1px); }
.register-card .btn:disabled { opacity:.55; cursor:not-allowed; }

.register-card .form-msg { margin:1.2rem 0 0; font-size:.8rem; font-weight:700; letter-spacing:.4px; min-height:1rem; }

@media (max-width:1100px){ .register-card { max-width:720px; margin:0 auto; } }
@media (max-width:600px){ .register-card { padding:2rem 1.4rem 2.2rem; border-radius:22px; } .register-card .field input[type=text], .register-card .field input[type=tel], .register-card .field input[type=email], .register-card .field input[type=file] { font-size:.88rem; } .register-card__head .form-title { font-size:1.6rem; } }

/* Ghost button for links */
.btn.btn--ghost { background:transparent; border:1px solid rgba(255,255,255,.2); color:#e3eef8; box-shadow:none; }
.btn.btn--ghost:hover { background:rgba(255,255,255,.06); }
.terms-inline { margin-top:.8rem; }
.terms-inline--right { margin-top:1rem; }

/* Modal styles */
.modal { position:fixed; inset:0; display:flex; align-items:center; justify-content:center; z-index:9999; }
.modal.hidden { display:none !important; }
.modal__overlay { position:absolute; inset:0; background:rgba(0,10,25,.7); backdrop-filter: blur(2px); }
.modal__content { position:relative; background:linear-gradient(160deg,rgba(8,50,105,.98),rgba(4,24,49,.98)); border:1px solid rgba(255,255,255,.1); border-radius:18px; padding:1rem; width:min(92vw, 960px); max-height:90vh; display:flex; flex-direction:column; box-shadow:0 12px 32px -10px rgba(0,12,32,.6); }
.modal__close { position:absolute; top:8px; right:10px; border:none; background:transparent; color:#fff; font-size:28px; cursor:pointer; }
.modal__figure { margin:0; padding:0; overflow:auto; border-radius:12px; background:#051a34; display:flex; align-items:center; justify-content:center; }
.modal__figure img { max-width:100%; height:auto; display:block; }
.modal__footer { display:flex; justify-content:flex-end; gap:.6rem; margin-top:.7rem; }

