*{box-sizing:border-box}
html,body{margin:0;padding:0;width:100%;min-height:100%;font-family:Inter,"Segoe UI",Arial,sans-serif}

/* LANDING MANTIDA */
.site-page{min-height:100vh;overflow-x:hidden;color:#fff;background:#111827}
.hero-site{width:100%;min-height:100vh;padding:32px 52px 46px;background:linear-gradient(90deg,rgba(0,0,0,.86),rgba(0,0,0,.62),rgba(0,0,0,.38)),url("https://images.unsplash.com/photo-1560066984-138dadb4c035?auto=format&fit=crop&w=1800&q=85");background-size:cover;background-position:center;background-repeat:no-repeat}
.site-navbar{width:100%;max-width:1280px;margin:0 auto;display:flex;align-items:center;justify-content:flex-end;position:relative;z-index:5}
.site-menu{display:flex;align-items:center;justify-content:flex-end;gap:24px;flex-wrap:wrap}
.site-menu a{color:#fff;text-decoration:none;font-size:14px;font-weight:900;text-shadow:0 2px 8px rgba(0,0,0,.45);transition:.2s}
.site-menu a:hover{color:#d946ef}
.site-menu .nav-login{padding:13px 22px;border-radius:10px;background:linear-gradient(135deg,#c026d3,#7c3aed);box-shadow:0 16px 28px rgba(124,58,237,.34)}
.hero-content{width:100%;max-width:1280px;min-height:calc(100vh - 120px);margin:0 auto;display:grid;grid-template-columns:560px 1fr;align-items:center;gap:64px;position:relative;z-index:2}
.hero-logo-wrapper{display:flex;align-items:center;justify-content:center}
.hero-main-logo{width:100%;max-width:545px;height:auto;display:block;object-fit:contain;filter:drop-shadow(0 30px 55px rgba(0,0,0,.58)) drop-shadow(0 0 32px rgba(255,255,255,.10));animation:logoFloat 5s ease-in-out infinite}
@keyframes logoFloat{0%{transform:translateY(0)}50%{transform:translateY(-10px)}100%{transform:translateY(0)}}
.hero-text{max-width:700px}
.hero-kicker{display:inline-flex;padding:10px 17px;border-radius:999px;background:rgba(192,38,211,.22);border:1px solid rgba(255,255,255,.20);margin-bottom:20px;color:#fff;font-size:13px;font-weight:950;box-shadow:0 12px 28px rgba(192,38,211,.15)}
.hero-text h1{margin:0;color:#fff;font-size:70px;line-height:1.02;font-weight:950;letter-spacing:-2px;text-shadow:0 5px 18px rgba(0,0,0,.36)}
.hero-text h1 span{color:#d946ef}
.hero-text p{max-width:620px;margin:24px 0 32px;color:#f8fafc;font-size:21px;line-height:1.6;font-weight:650;text-shadow:0 3px 12px rgba(0,0,0,.35)}
.hero-actions{display:flex;flex-wrap:wrap;gap:14px}
.btn-primary,.btn-outline{min-width:180px;height:56px;padding:0 24px;border-radius:10px;display:inline-flex;align-items:center;justify-content:center;text-decoration:none;font-size:14px;font-weight:950}
.btn-primary{color:#fff;background:linear-gradient(135deg,#c026d3,#7c3aed);box-shadow:0 16px 28px rgba(124,58,237,.36)}
.btn-outline{color:#fff;border:2px solid rgba(255,255,255,.78);background:rgba(255,255,255,.05)}

/* LOGIN RESPONSIVO PROFISSIONAL */
.login-page{min-height:100vh;overflow-x:hidden;color:#fff;background:radial-gradient(circle at 18% 12%,rgba(217,70,239,.38),transparent 28%),radial-gradient(circle at 86% 18%,rgba(124,58,237,.32),transparent 30%),linear-gradient(135deg,#12041f,#2e1065 45%,#7c3aed)}
.login-wrapper{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:clamp(18px,3vw,42px)}
.login-shell{width:100%;max-width:1120px;min-height:680px;display:grid;grid-template-columns:1.05fr .95fr;border-radius:34px;overflow:hidden;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.16);box-shadow:0 36px 110px rgba(0,0,0,.42),0 0 50px rgba(217,70,239,.16);backdrop-filter:blur(16px)}
.login-brand-panel{position:relative;padding:42px;min-height:680px;display:flex;flex-direction:column;justify-content:space-between;background:linear-gradient(135deg,rgba(4,12,32,.86),rgba(46,16,101,.58)),url("https://images.unsplash.com/photo-1560066984-138dadb4c035?auto=format&fit=crop&w=1400&q=85");background-size:cover;background-position:center}
.login-brand-panel::after{content:"";position:absolute;inset:0;background:radial-gradient(circle at 50% 38%,rgba(255,255,255,.10),transparent 28%),linear-gradient(180deg,rgba(0,0,0,.08),rgba(0,0,0,.35));pointer-events:none}
.login-brand-logo,.login-brand-content{position:relative;z-index:2}
.login-brand-logo{display:flex;width:max-content;max-width:100%;text-decoration:none}
.login-brand-logo img{width:100%;max-width:380px;height:auto;object-fit:contain;display:block;filter:drop-shadow(0 24px 46px rgba(0,0,0,.52)) drop-shadow(0 0 28px rgba(255,255,255,.16))}
.login-brand-content{max-width:470px}
.login-brand-content span{display:inline-flex;padding:10px 16px;border-radius:999px;margin-bottom:18px;background:rgba(217,70,239,.20);border:1px solid rgba(255,255,255,.20);color:#fff;font-size:13px;font-weight:950}
.login-brand-content h2{margin:0 0 16px;font-size:42px;line-height:1.05;letter-spacing:-1.5px;font-weight:950;color:#fff}
.login-brand-content p{margin:0;color:#e2e8f0;font-size:17px;line-height:1.65}
.login-card{min-height:680px;padding:clamp(30px,4vw,52px);display:flex;flex-direction:column;justify-content:center;background:rgba(4,12,32,.94);color:#fff}
.login-logo-mobile{display:none;justify-content:center;margin-bottom:22px}
.login-logo-mobile img{width:100%;max-width:280px;height:auto;object-fit:contain;filter:drop-shadow(0 16px 32px rgba(0,0,0,.40)) drop-shadow(0 0 24px rgba(255,255,255,.13))}
.login-heading{margin-bottom:26px}
.login-heading span{display:inline-flex;padding:8px 13px;border-radius:999px;margin-bottom:14px;background:#f3e8ff;color:#9333ea;font-size:12px;font-weight:950}
.login-card h1{margin:0 0 10px;font-size:32px;line-height:1.08;font-weight:950;letter-spacing:-.8px;color:#fff}
.login-card p{margin:0;color:#cbd5e1;font-size:15px;line-height:1.55}
.login-form{display:flex;flex-direction:column;gap:0}
.field{margin-bottom:17px}
.login-card label{display:block;margin:0 0 8px;color:#f8fafc;font-size:14px;font-weight:850}
.login-card input[type=email],.login-card input[type=password]{width:100%;height:56px;border:1px solid rgba(255,255,255,.14);border-radius:15px;padding:0 16px;outline:none;background:rgba(255,255,255,.97);color:#111827;font-size:15px;transition:.22s}
.login-card input[type=email]:focus,.login-card input[type=password]:focus{border-color:#d946ef;box-shadow:0 0 0 5px rgba(217,70,239,.18)}
.login-row{display:flex;align-items:center;justify-content:space-between;gap:14px;margin:2px 0 22px}
.remember{display:flex!important;align-items:center;gap:8px;margin:0!important;color:#e2e8f0!important;font-size:13px!important;font-weight:700!important;cursor:pointer}
.remember input{width:18px;height:18px;margin:0;accent-color:#d946ef}
.login-row a{color:#d946ef;text-decoration:none;font-size:13px;font-weight:950}
.login-row a:hover{text-decoration:underline}
.login-submit{width:100%;height:58px;border:0;border-radius:15px;color:#fff;background:linear-gradient(135deg,#d946ef,#7c3aed);box-shadow:0 18px 35px rgba(124,58,237,.34),0 0 24px rgba(217,70,239,.20);font-size:16px;font-weight:950;cursor:pointer;transition:.22s}
.login-submit:hover{transform:translateY(-2px);filter:brightness(1.05)}
.back-site{min-height:42px;margin-top:18px;display:flex;align-items:center;justify-content:center;color:#cbd5e1;text-decoration:none;font-size:13px;font-weight:850}
.back-site:hover{color:#d946ef}
.login-footer{display:block;margin-top:12px;text-align:center;color:#94a3b8;font-size:12px}
.alert{padding:12px 14px;border-radius:12px;margin-bottom:16px;font-size:14px}
.alert.success{color:#16a34a;background:#ecfdf3;border:1px solid #bbf7d0}
.alert.error{color:#e11d48;background:#fff1f2;border:1px solid #fecdd3}
.field-error{display:block;color:#fb7185;font-size:12px;margin:7px 0 0}

/* RESPONSIVO */
@media(max-width:1100px){
    .hero-content{grid-template-columns:1fr;text-align:center;gap:34px;padding:40px 0}
    .hero-main-logo{max-width:390px}
    .hero-text{margin:0 auto}
    .hero-text p{margin-left:auto;margin-right:auto}
    .hero-actions{justify-content:center}
    .login-shell{max-width:620px;grid-template-columns:1fr;min-height:auto}
    .login-brand-panel{display:none}
    .login-card{min-height:auto}
    .login-logo-mobile{display:flex}
    .login-heading{text-align:center}
}
@media(max-width:780px){
    .hero-site{padding:24px}
    .site-navbar{justify-content:center}
    .site-menu{justify-content:center;gap:14px}
    .hero-text h1{font-size:44px}
    .hero-text p{font-size:17px}
    .hero-main-logo{max-width:280px}
    .login-wrapper{padding:18px}
    .login-shell{border-radius:26px}
    .login-card{padding:30px 22px}
    .login-logo-mobile img{max-width:240px}
    .login-card h1{font-size:27px}
    .login-row{align-items:flex-start;flex-direction:column}
}
@media(max-width:420px){
    .login-wrapper{padding:12px}
    .login-card{padding:26px 18px}
    .login-logo-mobile img{max-width:210px}
    .login-card h1{font-size:24px}
    .login-card input[type=email],.login-card input[type=password],.login-submit{height:54px}
}


/* PERFIL LOGADO NA LANDING */
.site-profile-dropdown{position:relative;z-index:50}
.site-profile-button{min-height:56px;border:1px solid rgba(255,255,255,.18);border-radius:16px;padding:8px 12px;display:flex;align-items:center;gap:10px;color:#fff;background:rgba(15,23,42,.70);box-shadow:0 14px 32px rgba(0,0,0,.28);cursor:pointer}
.site-profile-avatar{width:40px;height:40px;border-radius:50%;display:grid;place-items:center;overflow:hidden;background:linear-gradient(135deg,#d946ef,#7c3aed);color:#fff;font-weight:950;font-size:14px;flex:0 0 40px}
.site-profile-avatar img{width:100%;height:100%;object-fit:cover;display:block}
.site-profile-info{display:flex;flex-direction:column;align-items:flex-start;line-height:1.1;min-width:110px}
.site-profile-info strong{max-width:150px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:#fff;font-size:13px;font-weight:950}
.site-profile-info small{margin-top:4px;color:#cbd5e1;font-size:12px;font-weight:750;text-transform:capitalize}
.site-profile-arrow{font-size:18px;color:#cbd5e1;transition:.2s}
.site-profile-dropdown.open .site-profile-arrow{transform:rotate(180deg)}
.site-profile-menu{position:absolute;right:0;top:calc(100% + 12px);width:310px;padding:14px;border-radius:20px;background:#0f213d;border:1px solid rgba(255,255,255,.14);box-shadow:0 30px 70px rgba(0,0,0,.42);display:none}
.site-profile-dropdown.open .site-profile-menu{display:block}
.site-profile-menu a,.site-profile-menu form button{width:100%;min-height:44px;border:0;border-radius:12px;padding:0 12px;display:flex;align-items:center;gap:10px;color:#e5eefb;background:transparent;text-decoration:none;font-size:14px;font-weight:850;text-align:left;cursor:pointer;font-family:inherit}
.site-profile-menu a:hover,.site-profile-menu form button:hover{background:rgba(255,255,255,.08);color:#fff}
.site-profile-menu form{margin:4px 0 0}
.site-public-link-box{margin:10px 0;padding:12px;border-radius:16px;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.10)}
.site-public-link-box span{display:block;margin-bottom:8px;color:#cbd5e1;font-size:12px;font-weight:900}
.site-public-link-box input{width:100%;height:38px;border:1px solid rgba(255,255,255,.12);border-radius:10px;padding:0 10px;color:#111827;background:#fff;font-size:12px;font-weight:700}
.site-public-link-box button{width:100%;height:38px;margin-top:8px;border:0;border-radius:10px;color:#fff;background:linear-gradient(135deg,#d946ef,#7c3aed);font-size:13px;font-weight:950;cursor:pointer}
.site-login-success{display:inline-flex;margin:0 0 14px;padding:10px 14px;border-radius:999px;background:#dcfce7;color:#166534;border:1px solid #bbf7d0;font-size:13px;font-weight:950}
.site-owner-link-card{max-width:620px;margin:0 0 24px;padding:16px 18px;border-radius:18px;background:rgba(15,23,42,.72);border:1px solid rgba(255,255,255,.16);box-shadow:0 20px 38px rgba(0,0,0,.22)}
.site-owner-link-card strong{display:block;margin-bottom:8px;color:#fff;font-size:14px;font-weight:950}
.site-owner-link-card div{padding:10px 12px;border-radius:12px;background:rgba(255,255,255,.10);color:#f8fafc;font-size:13px;font-weight:850;word-break:break-all}
.site-owner-link-card a{min-height:40px;margin:12px 8px 0 0;padding:0 14px;border-radius:10px;display:inline-flex;align-items:center;justify-content:center;text-decoration:none;color:#fff;background:linear-gradient(135deg,#d946ef,#7c3aed);font-size:13px;font-weight:950}
.site-owner-link-card a:last-child{background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.22)}
@media(max-width:780px){.site-profile-dropdown{width:100%}.site-profile-button{width:100%;justify-content:center}.site-profile-menu{left:50%;right:auto;transform:translateX(-50%);width:min(92vw,310px)}.site-owner-link-card{margin-left:auto;margin-right:auto}}
