/* O&C CRM Login v34 Premium Industrial
   Baseado no novo design do compressor: azul petróleo, grafite, cinza industrial.
   O logo textual O&C foi mantido sem redesenho de marca. */

:root{
    --oc34-petrol:#007a83;
    --oc34-petrol-dark:#005e66;
    --oc34-petrol-soft:#1bb7bd;
    --oc34-graphite:#11181c;
    --oc34-graphite-2:#1e2428;
    --oc34-gray:#dce2e5;
    --oc34-gray-2:#b9c4c9;
    --oc34-ice:#f4f7f8;
    --oc34-white:#ffffff;
    --oc34-line:rgba(202,216,222,.34);
    --oc34-shadow:0 34px 90px rgba(0,0,0,.38);
}

body.oc-login-v34{
    margin:0;
    min-height:100vh;
    overflow:hidden;
    color:var(--oc34-ice);
    background:
        radial-gradient(circle at 8% 10%, rgba(255,255,255,.14), transparent 24%),
        radial-gradient(circle at 80% 20%, rgba(0,122,131,.20), transparent 26%),
        linear-gradient(135deg,#0b1114 0%,#151d21 48%,#0c1114 100%);
    font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}

.oc-login-shell{
    position:relative;
    display:grid;
    grid-template-columns:minmax(0,1.08fr) minmax(420px,.92fr);
    min-height:100vh;
}

.oc-login-shell::before{
    content:"";
    position:absolute;
    inset:0;
    background:
      linear-gradient(90deg, rgba(0,0,0,.20), transparent 45%, rgba(0,0,0,.32)),
      repeating-linear-gradient(90deg, rgba(255,255,255,.025) 0 1px, transparent 1px 130px);
    pointer-events:none;
}

.oc-login-hero{
    position:relative;
    padding:52px 52px 34px;
    display:flex;
    flex-direction:column;
    justify-content:space-between;
    overflow:hidden;
    background:
      linear-gradient(100deg,rgba(8,14,17,.98) 0%,rgba(14,23,27,.88) 55%,rgba(8,14,17,.80) 100%);
}

.oc-login-hero::after{
    content:"";
    position:absolute;
    top:-9%;
    right:-18px;
    width:180px;
    height:118%;
    transform:skewX(-13deg);
    border-left:5px solid var(--oc34-petrol);
    border-right:1px solid rgba(255,255,255,.10);
    background:linear-gradient(180deg,rgba(0,122,131,.22),rgba(0,122,131,.04));
    box-shadow:-18px 0 50px rgba(0,122,131,.22);
    pointer-events:none;
}

.oc-industrial-glow{
    position:absolute;
    inset:0;
    background:
      radial-gradient(circle at 22% 12%, rgba(255,255,255,.20), transparent 22%),
      radial-gradient(circle at 58% 74%, rgba(0,122,131,.30), transparent 30%),
      linear-gradient(180deg,rgba(255,255,255,.03),rgba(0,0,0,.08));
    pointer-events:none;
}

.oc-login-logo{
    position:relative;
    z-index:2;
    display:flex;
    align-items:center;
    gap:16px;
    width:max-content;
}

.oc-logo-mark{
    font-weight:950;
    font-size:42px;
    line-height:.88;
    letter-spacing:-3px;
    color:#f5fbfc;
    text-shadow:0 14px 32px rgba(0,0,0,.35);
}
.oc-logo-mark span{ color:#16b7b0; }
.oc-logo-copy strong{
    display:block;
    color:#f8fbfc;
    font-size:13px;
    letter-spacing:3.2px;
    line-height:1;
}
.oc-logo-copy small{
    display:block;
    margin-top:7px;
    color:#4fd3d7;
    font-weight:800;
    font-size:11px;
    letter-spacing:2.6px;
    text-transform:uppercase;
}

.oc-login-copy{
    position:relative;
    z-index:2;
    max-width:610px;
    margin-top:36px;
}
.oc-eyebrow{
    display:inline-flex;
    align-items:center;
    gap:8px;
    color:#43d5d7;
    font-weight:900;
    letter-spacing:2px;
    text-transform:uppercase;
    font-size:12px;
}
.oc-login-copy h1{
    margin:20px 0 18px;
    color:#fff;
    font-size:clamp(38px,4.4vw,70px);
    line-height:.98;
    letter-spacing:-2.4px;
    text-wrap:balance;
}
.oc-login-copy h1 span{
    color:#18b7bc;
    text-shadow:0 0 34px rgba(0,122,131,.45);
}
.oc-login-copy p{
    max-width:540px;
    margin:0;
    color:#d2dbe0;
    font-size:18px;
    line-height:1.62;
}

.oc-compressor-stage{
    position:absolute;
    z-index:1;
    right:38px;
    bottom:118px;
    width:min(58vw,860px);
    opacity:.92;
    filter:drop-shadow(0 28px 45px rgba(0,0,0,.50));
}
.oc-compressor-stage::before{
    content:"";
    position:absolute;
    inset:50% 12% 4% 20%;
    background:rgba(0,122,131,.25);
    filter:blur(44px);
}
.oc-compressor-stage img{
    width:100%;
    display:block;
    border-radius:10px;
    mask-image:linear-gradient(90deg, transparent 0%, #000 12%, #000 86%, transparent 100%);
    -webkit-mask-image:linear-gradient(90deg, transparent 0%, #000 12%, #000 86%, transparent 100%);
}

.oc-feature-grid{
    position:relative;
    z-index:3;
    display:grid;
    grid-template-columns:repeat(3,minmax(0,1fr));
    gap:12px;
    max-width:780px;
    margin-top:auto;
}
.oc-feature-grid article,
.oc-trust-strip,
.oc-protected-panel{
    border:1px solid var(--oc34-line);
    background:linear-gradient(180deg,rgba(255,255,255,.10),rgba(255,255,255,.045));
    box-shadow:0 18px 50px rgba(0,0,0,.20);
    backdrop-filter:blur(16px);
}
.oc-feature-grid article{
    min-height:124px;
    padding:18px;
    border-radius:18px;
}
.oc-feature-grid span{
    width:44px;
    height:44px;
    display:grid;
    place-items:center;
    border-radius:14px;
    color:#cfffff;
    background:linear-gradient(135deg,var(--oc34-petrol),rgba(0,122,131,.28));
    box-shadow:0 12px 32px rgba(0,122,131,.22);
    font-size:20px;
    margin-bottom:14px;
}
.oc-feature-grid strong{
    display:block;
    color:#fff;
    font-size:15px;
}
.oc-feature-grid p{
    margin:8px 0 0;
    color:#c5d0d5;
    line-height:1.45;
    font-size:13px;
}

.oc-trust-strip{
    position:relative;
    z-index:3;
    margin-top:14px;
    max-width:780px;
    display:grid;
    grid-template-columns:repeat(3,1fr);
    gap:0;
    border-radius:18px;
    overflow:hidden;
}
.oc-trust-strip div{
    padding:16px 18px;
    border-right:1px solid rgba(255,255,255,.10);
}
.oc-trust-strip div:last-child{ border-right:0; }
.oc-trust-strip strong{
    display:block;
    color:#fff;
    font-size:13px;
}
.oc-trust-strip span{
    display:block;
    margin-top:4px;
    color:#aebbc1;
    font-size:12px;
}

.oc-login-panel{
    position:relative;
    z-index:2;
    display:flex;
    flex-direction:column;
    justify-content:center;
    align-items:center;
    padding:48px;
    background:
      radial-gradient(circle at 50% 30%, rgba(0,122,131,.13), transparent 28%),
      linear-gradient(180deg,rgba(10,15,18,.92),rgba(8,12,15,.98));
}

.oc-login-card{
    width:min(100%,560px);
    border:1px solid rgba(224,235,238,.30);
    border-radius:28px;
    padding:42px;
    background:
      linear-gradient(180deg,rgba(255,255,255,.08),rgba(255,255,255,.035));
    box-shadow:var(--oc34-shadow);
    backdrop-filter:blur(18px);
}

.oc-secure-icon{
    width:74px;
    height:74px;
    display:grid;
    place-items:center;
    margin:0 auto 22px;
    border-radius:24px;
    color:#77ffff;
    border:2px solid rgba(0,190,198,.70);
    background:rgba(0,122,131,.13);
    font-size:34px;
    font-weight:900;
    box-shadow:0 0 45px rgba(0,122,131,.20);
}

.oc-login-head{
    text-align:center;
    margin-bottom:28px;
}
.oc-login-head h2{
    margin:14px 0 10px;
    color:#fff;
    font-size:34px;
    letter-spacing:-.8px;
}
.oc-login-head p{
    margin:0;
    color:#b8c5cb;
    line-height:1.5;
}

.oc-field{
    display:block;
    color:#f7fbfc;
    font-weight:800;
    margin-top:18px;
}
.oc-input-wrap{
    margin-top:8px;
    display:flex;
    align-items:center;
    gap:12px;
    height:58px;
    padding:0 16px;
    border:1px solid rgba(211,226,232,.34);
    border-radius:13px;
    background:rgba(2,8,11,.56);
    transition:.18s ease;
}
.oc-input-wrap:focus-within{
    border-color:rgba(34,217,222,.82);
    box-shadow:0 0 0 4px rgba(0,122,131,.18);
}
.oc-input-icon{
    color:#32cdd1;
    width:22px;
    text-align:center;
}
.oc-input-wrap input{
    flex:1;
    border:0;
    outline:0;
    background:transparent;
    color:#fff;
    font-size:16px;
    font-weight:700;
}
.oc-input-wrap input::placeholder{ color:#74838a; }

.oc-submit-button{
    width:100%;
    height:64px;
    margin-top:28px;
    border:0;
    border-radius:14px;
    color:#fff;
    font-weight:950;
    font-size:18px;
    cursor:pointer;
    background:linear-gradient(135deg,#22bec7,var(--oc34-petrol-dark));
    box-shadow:0 24px 50px rgba(0,122,131,.34);
    transition:.18s ease;
}
.oc-submit-button:hover{
    transform:translateY(-1px);
    filter:saturate(1.08) brightness(1.04);
    box-shadow:0 30px 60px rgba(0,122,131,.42);
}

.oc-login-feedback{
    min-height:20px;
    margin:14px 0 0;
    text-align:center;
    font-weight:800;
}
.oc-login-feedback.success{ color:#76f2d0; }
.oc-login-feedback.error{ color:#ff9d9d; }

.oc-protected-panel{
    margin-top:28px;
    border-radius:20px;
    padding:22px;
}
.oc-panel-title{
    display:flex;
    justify-content:center;
    align-items:center;
    gap:14px;
    margin-bottom:16px;
    color:#43d5d7;
    font-weight:900;
    letter-spacing:1.6px;
    text-transform:uppercase;
    font-size:12px;
}
.oc-protected-panel ul{
    list-style:none;
    padding:0;
    margin:0;
    display:grid;
    gap:14px;
}
.oc-protected-panel li{
    position:relative;
    padding-left:28px;
}
.oc-protected-panel li::before{
    content:"";
    position:absolute;
    left:0;
    top:7px;
    width:11px;
    height:11px;
    border-radius:50%;
    background:var(--oc34-petrol-soft);
    box-shadow:0 0 18px rgba(0,190,198,.5);
}
.oc-protected-panel strong{
    display:block;
    color:#fff;
    font-size:15px;
}
.oc-protected-panel small{
    display:block;
    color:#b3c1c7;
    margin-top:4px;
    line-height:1.35;
}

.oc-login-footer{
    width:min(100%,560px);
    display:flex;
    justify-content:center;
    gap:16px;
    flex-wrap:wrap;
    margin-top:22px;
    color:#a4b2b8;
    font-size:12px;
}
.oc-login-footer span:not(:last-child)::after{
    content:"•";
    margin-left:16px;
    color:#31c9cf;
}

@media (max-width:1080px){
    body.oc-login-v34{ overflow:auto; }
    .oc-login-shell{ grid-template-columns:1fr; }
    .oc-login-hero{ min-height:720px; }
    .oc-login-panel{ padding:34px 22px; }
}
@media (max-width:720px){
    .oc-login-hero{ padding:30px 22px; min-height:780px; }
    .oc-login-copy h1{ font-size:40px; }
    .oc-feature-grid,.oc-trust-strip{ grid-template-columns:1fr; }
    .oc-login-card{ padding:28px 22px; }
    .oc-compressor-stage{ width:110vw; right:-34vw; bottom:250px; opacity:.55; }
}
