/*
 * Login / Create account — pagina /login, 1:1 după mock-ul dev.rotocon.world/login.html.
 * Fișier de sine stătător: include tokenii `--rwo-*` din :root (site.css) + toate
 * regulile `.auth` / `.rwo-eyebrow` extrase din site.css, plus reguli noi pentru
 * elemente care nu există în mock (selector rol, checkbox-uri de consimțământ,
 * interstitial choose-role) — scrise în același limbaj vizual (glass card, roșu #e5322d).
 *
 * @package Rotocon\Child
 */

:root{
	--rwo-red:#FF0000;
	--rwo-red-hover:#D90000;
	--rwo-anthracite:#403E3D;
	--rwo-ink:#1d1d1d;
	--rwo-grey:#555555;
	--rwo-sand:#C2BCB2;
	--rwo-cream:#F2F1ED;
	--rwo-white:#FFFFFF;
	--rwo-line:rgba(64,62,61,.12);
	--rwo-ease:cubic-bezier(0,0,.2,1);
	--rwo-dur:.24s;
	--rwo-font:"General Sans",-apple-system,BlinkMacSystemFont,"Inter","Helvetica Neue",Arial,sans-serif;
	--rwo-mono:ui-monospace,"SFMono-Regular",Menlo,monospace;
	--rwo-pad-inline:clamp(20px,3vw,48px);
}

.rwo-eyebrow{font-weight:600;text-transform:uppercase;letter-spacing:.16em;color:var(--rwo-red);font-size:.78rem}

.auth{position:relative;min-height:100vh;display:flex;align-items:center;justify-content:center;padding:clamp(96px,14vh,150px) var(--rwo-pad-inline) clamp(48px,8vh,80px);background:#36352f;overflow:hidden}
.auth::before{content:"";position:absolute;inset:0;z-index:0;background:url("../assets/img/hero-press.jpg") center/cover no-repeat;filter:blur(26px) brightness(.5) saturate(.9);transform:scale(1.16)}
.auth::after{content:"";position:absolute;inset:0;z-index:0;background:radial-gradient(120% 90% at 50% 40%,rgba(54,53,47,.5),rgba(54,53,47,.82))}
/* Video-background variant (NexusGate-inspired) */
.auth--video::before{display:none}
.auth-video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0}
.auth--video::after{content:"";position:absolute;inset:0;z-index:1;background:radial-gradient(130% 100% at 50% 40%,rgba(54,53,47,.45),rgba(54,53,47,.86))}
.auth-card{position:relative;z-index:2;width:100%;max-width:460px;background:#fff;border-radius:6px;box-shadow:0 40px 90px rgba(0,0,0,.4);padding:clamp(28px,4vw,44px)}
/* Frosted glass card over the video */
.auth-card--glass{background:rgba(28,26,25,.55);-webkit-backdrop-filter:blur(22px) saturate(130%);backdrop-filter:blur(22px) saturate(130%);border:1px solid rgba(242,241,237,.16);border-radius:10px;box-shadow:0 40px 100px rgba(0,0,0,.5),inset 0 1px 0 rgba(255,255,255,.08)}
.auth-card--glass .rwo-eyebrow{color:var(--rwo-red)}
.auth-card--glass h1{color:#fff}
.auth-card--glass .auth-sub{color:rgba(242,241,237,.72)}
.auth-card--glass .auth-divider{color:rgba(242,241,237,.5)}
.auth-card--glass .auth-divider::before,.auth-card--glass .auth-divider::after{background:rgba(242,241,237,.18)}
.auth-card--glass .auth-field input,.auth-card--glass .auth-field select{background:rgba(255,255,255,.06);border-color:rgba(242,241,237,.2);color:#fff}
.auth-card--glass .auth-field input::placeholder{color:rgba(242,241,237,.45)}
.auth-card--glass .auth-field input:focus,.auth-card--glass .auth-field select:focus{border-color:rgba(242,241,237,.7);background:rgba(255,255,255,.1)}
.auth-card--glass .auth-foot{color:rgba(242,241,237,.66)}
.auth-card--glass .auth-secure{color:rgba(242,241,237,.5)}
.auth-card--glass .auth-terms{color:rgba(242,241,237,.45)}
.auth-card--glass .auth-prov{background:rgba(255,255,255,.95)}
.auth-card--glass .auth-prov--linkedin{background:#0a66c2}
.auth-card--glass .auth-prov--facebook{background:#1877f2}
.auth-card .rwo-eyebrow{display:block;text-align:center;margin-bottom:.7rem}
.auth-card h1{font-family:var(--rwo-font);font-weight:600;text-transform:uppercase;letter-spacing:.04em;font-size:clamp(1.4rem,2.4vw,1.85rem);color:var(--rwo-anthracite);text-align:center;line-height:1.1;margin:0}
.auth-card .auth-sub{text-align:center;color:var(--rwo-grey);font-size:.94rem;line-height:1.55;margin:.8rem 0 1.8rem}
.auth-providers{display:flex;flex-direction:column;gap:.7rem}
/* Icon-only provider buttons — logos only, circular, interactive */
.auth-providers--icons{flex-direction:row;justify-content:center;gap:1.1rem}
.auth-providers--icons .auth-prov{width:60px;height:60px;min-height:0;padding:0;border-radius:50%;gap:0;transition:transform .24s var(--rwo-ease),box-shadow .24s var(--rwo-ease),background var(--rwo-ease)}
.auth-providers--icons .auth-prov svg{width:26px;height:26px}
.auth-providers--icons .auth-prov:hover{transform:translateY(-3px);box-shadow:0 12px 26px rgba(54,53,47,.18)}
.auth-providers--icons .auth-prov:active{transform:translateY(-1px) scale(.97)}
.auth-prov{display:flex;align-items:center;justify-content:center;gap:.7rem;min-height:50px;border-radius:3px;border:1px solid var(--rwo-line);background:#fff;color:var(--rwo-anthracite);font:600 .9rem/1 var(--rwo-font);letter-spacing:.02em;cursor:pointer;transition:background var(--rwo-dur) var(--rwo-ease),box-shadow var(--rwo-dur) var(--rwo-ease),border-color var(--rwo-dur) var(--rwo-ease)}
.auth-prov:hover{background:#faf9f7;box-shadow:0 6px 18px rgba(54,53,47,.1)}
.auth-prov svg,.auth-prov img{width:20px;height:20px;flex:0 0 auto}
.auth-prov--linkedin{background:#0a66c2;color:#fff;border-color:#0a66c2}
.auth-prov--linkedin:hover{background:#08589f;border-color:#08589f}
.auth-prov--facebook{background:#1877f2;color:#fff;border-color:#1877f2}
.auth-prov--facebook:hover{background:#1264d3;border-color:#1264d3}
.auth-divider{display:flex;align-items:center;gap:1rem;margin:1.6rem 0;color:var(--rwo-grey);font-size:.72rem;letter-spacing:.14em;text-transform:uppercase}
.auth-divider::before,.auth-divider::after{content:"";flex:1 1 auto;height:1px;background:var(--rwo-line)}
.auth-form{display:flex;flex-direction:column;gap:1rem}
.auth-field{display:flex;flex-direction:column;gap:.45rem}
.auth-field label{font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;color:var(--rwo-grey)}
.auth-field input{font:500 1rem/1.4 var(--rwo-font);color:var(--rwo-anthracite);background:#fff;border:1px solid var(--rwo-line);border-radius:3px;padding:.85rem .95rem;transition:border-color var(--rwo-dur) var(--rwo-ease)}
.auth-field input::placeholder{color:rgba(64,62,61,.4);font-family:var(--rwo-mono);font-size:.92rem;letter-spacing:.02em}
.auth-field input:focus{outline:0;border-color:var(--rwo-anthracite)}
.auth-row{display:flex;justify-content:flex-end;margin-top:-.3rem}
.auth-row a{font-size:.8rem;color:var(--rwo-red);font-weight:600}
.auth-submit{align-self:center;min-height:44px;margin-top:.3rem;padding:.72rem 2.6rem;border:0;border-radius:999px;background:var(--rwo-red);color:#fff;font:600 .72rem/1 var(--rwo-font);letter-spacing:.2em;text-transform:uppercase;cursor:pointer;box-shadow:0 6px 18px rgba(255,0,0,.18);transition:background var(--rwo-dur) var(--rwo-ease),transform var(--rwo-dur) var(--rwo-ease),box-shadow var(--rwo-dur) var(--rwo-ease)}
.auth-submit:hover{background:var(--rwo-red-hover);box-shadow:0 10px 24px rgba(255,0,0,.26)}
.auth-submit:active{transform:translateY(1px) scale(.98)}
.auth-foot{margin-top:1.6rem;text-align:center;font-size:.9rem;color:var(--rwo-grey)}
.auth-foot a{color:var(--rwo-red);font-weight:600;cursor:pointer}
.auth-terms{margin-top:1.2rem;text-align:center;font-size:.74rem;line-height:1.5;color:rgba(64,62,61,.5)}
.auth-secure{display:flex;align-items:center;justify-content:center;gap:.4rem;margin-top:1.1rem;color:rgba(64,62,61,.5);font-size:.72rem;letter-spacing:.06em}
.auth-secure svg{width:13px;height:13px}
.auth-hidden{display:none!important}
/* Login tabs + inline error */
.auth-tabs{display:flex;gap:.4rem;margin-bottom:1.6rem;background:rgba(255,255,255,.06);border-radius:999px;padding:.3rem}
.auth-tab{flex:1 1 auto;border:0;cursor:pointer;background:transparent;color:rgba(242,241,237,.7);font:600 .72rem/1 var(--rwo-font);letter-spacing:.12em;text-transform:uppercase;padding:.7rem .6rem;border-radius:999px;transition:background .24s var(--rwo-ease),color .24s var(--rwo-ease)}
.auth-tab.is-on{background:var(--rwo-red);color:#fff}
.auth-card:not(.auth-card--glass) .auth-tabs{background:rgba(64,62,61,.06)}
.auth-card:not(.auth-card--glass) .auth-tab{color:var(--rwo-grey)}
.auth-error{margin:0;color:#ff6a6a;font-size:.82rem;line-height:1.4;display:flex;align-items:flex-start;gap:.4rem}
.auth-error::before{content:"!";flex:0 0 auto;width:16px;height:16px;border-radius:50%;background:#ff4d4d;color:#fff;font-size:.7rem;font-weight:700;display:inline-flex;align-items:center;justify-content:center;margin-top:.05rem}
.auth-prov.is-loading{pointer-events:none;opacity:.75}
.auth-overlay{position:fixed;inset:0;z-index:80;display:none;align-items:center;justify-content:center;background:rgba(54,53,47,.82);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}
.auth-overlay.is-on{display:flex}
.auth-overlay__box{text-align:center;color:var(--rwo-cream)}
.auth-spinner{width:46px;height:46px;margin:0 auto 1.2rem;border:3px solid rgba(242,241,237,.25);border-top-color:var(--rwo-red);border-radius:50%;animation:authspin .8s linear infinite}
@keyframes authspin{to{transform:rotate(360deg)}}
.auth-overlay__box p{font-size:.86rem;letter-spacing:.14em;text-transform:uppercase;color:rgba(242,241,237,.8)}
@media (prefers-reduced-motion:reduce){.auth-spinner{animation:none}}

/*
 * Elemente noi (nu există în mock) — selector rol + consimțământ + link social ca <a>,
 * scrise în același limbaj vizual (glass card, roșu accent #e5322d cerut de task).
 */
.auth-field--role select{font:500 1rem/1.4 var(--rwo-font);color:var(--rwo-anthracite);background:#fff;border:1px solid var(--rwo-line);border-radius:3px;padding:.85rem .95rem;appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23403E3D' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .9rem center;background-size:14px;transition:border-color var(--rwo-dur) var(--rwo-ease)}
.auth-field--role select:focus{outline:0;border-color:var(--rwo-anthracite)}
.auth-card--glass .auth-field--role select{color:#fff}
.auth-card--glass .auth-field--role select option{color:var(--rwo-anthracite)}
.auth-field--role label{color:rgba(255,255,255,.85);font-size:.8rem;letter-spacing:.02em}

.auth-consent{display:flex;align-items:flex-start;gap:.6rem;font-size:.8rem;line-height:1.5;color:rgba(242,241,237,.72);cursor:pointer}
.auth-consent input{flex:0 0 auto;width:16px;height:16px;margin-top:.15rem;accent-color:#e5322d;cursor:pointer}
.auth-consent a{color:#e5322d;font-weight:600;text-decoration:underline;text-underline-offset:2px}
.auth-card:not(.auth-card--glass) .auth-consent{color:var(--rwo-grey)}

/* Social: butoanele rămân <a> stilizate identic cu .auth-prov — fără schimbare vizuală. */
a.auth-prov{text-decoration:none}

/* Fix: [hidden] pierdea în fața lui display:flex — badge-ul de eroare apărea gol la load. */
.auth-error[hidden] { display: none; }

/* Reset minim — regulile de mai sus veneau din site.css care avea propriul reset global. */
body { margin: 0; font-family: var(--rwo-font, 'General Sans', Arial, sans-serif); }
.auth a { text-decoration: none; }
