/* ── LOGIN / SIGNUP MODAL ── */
.login-overlay{
  position:fixed;inset:0;z-index:5000;
  background:rgba(10,10,10,.55);
  backdrop-filter:blur(8px);
  -webkit-backdrop-filter:blur(8px);
  display:flex;align-items:center;justify-content:center;
  opacity:0;pointer-events:none;
  transition:opacity .35s ease;
  padding:20px;
}
.login-overlay.open{opacity:1;pointer-events:auto;}

.login-modal{
  position:relative;
  width:100%;max-width:480px;
  background:var(--white);
  border-radius:24px;
  box-shadow:0 32px 80px rgba(0,0,0,.18),0 0 0 1px rgba(0,0,0,.06);
  padding:48px 40px 40px;
  transform:translateY(30px) scale(.96);
  transition:transform .4s cubic-bezier(.2,.9,.3,1.15);
  overflow:hidden;
}
.login-overlay.open .login-modal{transform:translateY(0) scale(1);}

/* Decorative gradient blob inside modal */
.login-modal::before{
  content:'';position:absolute;top:-80px;right:-80px;
  width:220px;height:220px;border-radius:50%;
  background:radial-gradient(circle,rgba(255,92,0,.12),transparent 70%);
  pointer-events:none;
}
.login-modal::after{
  content:'';position:absolute;bottom:-60px;left:-60px;
  width:180px;height:180px;border-radius:50%;
  background:radial-gradient(circle,rgba(139,92,246,.08),transparent 70%);
  pointer-events:none;
}

.login-close{
  position:absolute;top:18px;right:18px;
  width:36px;height:36px;border-radius:10px;
  border:1.5px solid var(--gray-200);background:var(--white);
  display:flex;align-items:center;justify-content:center;
  font-size:16px;color:var(--gray-500);
  transition:all .25s;cursor:pointer;z-index:1;
}
.login-close:hover{background:var(--gray-100);color:var(--ink);border-color:var(--gray-300);transform:rotate(90deg);}

.login-title{
  font-size:26px;font-weight:800;color:var(--ink);
  letter-spacing:-1px;margin-bottom:6px;
  position:relative;z-index:1;
}
.login-subtitle{
  font-size:14px;color:var(--gray-500);margin-bottom:32px;
  position:relative;z-index:1;
}

/* Google button */
.btn-google{
  display:flex;align-items:center;justify-content:center;gap:12px;
  width:100%;padding:14px 24px;
  background:var(--white);
  border:1.5px solid var(--gray-200);
  border-radius:14px;
  font-size:15px;font-weight:600;color:var(--ink);
  font-family:inherit;cursor:pointer;
  transition:all .3s cubic-bezier(.2,.9,.3,1.1);
  position:relative;z-index:1;
}
.btn-google:hover{
  border-color:var(--gray-300);
  box-shadow:0 8px 24px rgba(0,0,0,.08);
  transform:translateY(-2px);
}
.btn-google:active{transform:translateY(0);box-shadow:none;}
.btn-google .g-icon{width:20px;height:20px;flex-shrink:0;}

.login-divider{
  display:flex;align-items:center;gap:16px;
  margin:28px 0;position:relative;z-index:1;
}
.login-divider::before,.login-divider::after{
  content:'';flex:1;height:1px;background:var(--gray-200);
}
.login-divider span{
  font-size:12px;font-weight:600;color:var(--gray-400);
  text-transform:uppercase;letter-spacing:1px;
}

/* Form fields */
.login-form{display:flex;flex-direction:column;gap:16px;position:relative;z-index:1;}
.login-field{position:relative;}
.login-field label{
  display:block;font-size:12px;font-weight:700;
  color:var(--gray-500);letter-spacing:.5px;
  text-transform:uppercase;margin-bottom:8px;
}
.login-field input{
  width:100%;padding:13px 16px;
  background:var(--gray-50);
  border:1.5px solid var(--gray-200);
  border-radius:12px;font-size:15px;
  color:var(--ink);font-family:inherit;
  transition:all .25s;outline:none;
}
.login-field input::placeholder{color:var(--gray-400);}
.login-field input:focus{
  border-color:var(--orange);
  background:var(--white);
  box-shadow:0 0 0 4px rgba(255,92,0,.08);
}
.login-field .pw-wrap{position:relative;}
.login-field .pw-wrap input{width:100%;padding-right:46px;}
.pw-toggle{
  position:absolute;right:1px;top:1px;bottom:1px;
  width:44px;border:none;background:transparent;
  display:flex;align-items:center;justify-content:center;
  color:var(--gray-400);font-size:15px;cursor:pointer;
  border-radius:0 12px 12px 0;
  transition:color .2s;
}
.pw-toggle:hover{color:var(--ink);}

.login-forgot{text-align:right;margin-top:-8px;}
.login-forgot a{
  font-size:13px;font-weight:600;color:var(--orange);
  transition:color .2s;
}
.login-forgot a:hover{color:var(--orange-2);}

.login-submit{
  width:100%;padding:14px 24px;margin-top:8px;
  background:var(--ink);color:var(--white);
  border:none;border-radius:14px;
  font-size:15px;font-weight:700;font-family:inherit;
  cursor:pointer;position:relative;overflow:hidden;
  transition:all .3s cubic-bezier(.2,.9,.3,1.1);
}
.login-submit::before{
  content:'';position:absolute;inset:0;
  background:linear-gradient(135deg,var(--orange),var(--orange-2));
  opacity:0;transition:opacity .3s;
}
.login-submit span{position:relative;z-index:1;display:inline-flex;align-items:center;gap:8px;}
.login-submit:hover::before{opacity:1;}
.login-submit:hover{transform:translateY(-2px);box-shadow:var(--shadow-orange);}
.login-submit:active{transform:translateY(0);}

.login-footer{
  text-align:center;margin-top:28px;
  font-size:13px;color:var(--gray-500);
  position:relative;z-index:1;
}
.login-footer a{color:var(--orange);font-weight:700;transition:color .2s;}
.login-footer a:hover{color:var(--orange-2);}

@keyframes shake{
  0%,100%{transform:translateX(0);}
  20%{transform:translateX(-6px);}
  40%{transform:translateX(6px);}
  60%{transform:translateX(-4px);}
  80%{transform:translateX(4px);}
}

/* ════ LANGUAGE SWITCHER ════ */
.lang-wrapper{position:relative;}
.lang-btn{
  display:inline-flex;align-items:center;gap:6px;
  background:none;border:none;
  border-radius:8px;cursor:pointer;
  padding:5px 10px;font-size:13px;font-weight:500;
  color:var(--ink);font-family:inherit;
  transition:all .2s;
}
.lang-btn:hover{background:var(--gray-50);color:var(--orange);}
.lang-btn .lang-globe{font-size:14px;color:var(--gray-500);transition:color .2s;}
.lang-btn:hover .lang-globe{color:var(--orange);}
.lang-caret{font-size:10px;color:var(--gray-400);transition:transform .2s;}
.lang-wrapper.open .lang-caret{transform:rotate(180deg);}
.lang-dropdown{
  position:absolute;top:calc(100% + 8px);right:0;
  min-width:150px;
  background:var(--white);
  border:1px solid var(--gray-200);
  border-radius:12px;
  box-shadow:0 16px 48px rgba(0,0,0,.10),0 4px 12px rgba(0,0,0,.06);
  z-index:200;
  opacity:0;pointer-events:none;
  transform:translateY(-8px);
  transition:opacity .2s,transform .2s;
  overflow:hidden;
}
.lang-dropdown.open{opacity:1;pointer-events:auto;transform:translateY(0);}
.lang-item{
  display:flex;align-items:center;gap:10px;
  padding:10px 14px;cursor:pointer;
  font-size:13px;color:var(--ink);
  transition:background .15s;
}
.lang-item:hover{background:var(--gray-50);}
.lang-item.active{background:var(--gray-50);font-weight:600;}
.lang-flag{font-size:16px;}
.lang-check{margin-left:auto;color:var(--orange);opacity:0;font-size:12px;}
.lang-item.active .lang-check{opacity:1;}

/* Mobile menu language section */
.mob-lang-section{padding:14px 0 8px;border-top:1px solid var(--gray-200);margin-top:14px;}
.mob-lang-item{display:flex;align-items:center;padding:10px 16px;font-size:14px;font-weight:500;transition:color .15s;margin-bottom:4px;border-radius:10px;}
.mob-lang-item:hover{color:var(--orange);}
.mob-lang-flag{font-size:18px;line-height:1;margin-right:12px;}
.mob-lang-text{flex:1;text-align:left;}
.mob-lang-check{margin-left:16px;color:var(--orange);font-size:12px;}

/* ════ BUTTONS ════ */
.btn{
  display:inline-flex;align-items:center;gap:8px;
  padding:11px 22px;border-radius:10px;font-size:14px;font-weight:700;
  border:none;transition:all .25s cubic-bezier(.2,.9,.3,1.2);
  font-family:inherit;white-space:nowrap;position:relative;overflow:hidden;
}
.btn-ghost{background:transparent;border:1.5px solid var(--gray-200);color:var(--gray-600);text-align:center;}
.btn-ghost:hover{border-color:var(--ink);color:var(--ink);}
.btn-dark{background:var(--ink);color:var(--white);}
.btn-dark::before{
  content:'';position:absolute;inset:0;
  background:linear-gradient(135deg,var(--orange),var(--orange-2));
  opacity:0;transition:opacity .3s;
}
.btn-dark span{position:relative;z-index:1;display:inline-flex;align-items:center;gap:8px;}
.btn-dark:hover::before{opacity:1;}
.btn-dark:hover{transform:translateY(-2px);box-shadow:var(--shadow-orange);}
.btn-orange{
  background:var(--orange);color:var(--white);
  position:relative;
  box-shadow:0 4px 16px rgba(255,92,0,.25);
}
.btn-orange::before{
  content:'';position:absolute;inset:0;
  background:linear-gradient(135deg,#ff7a2e,#ff5c00 60%,#ff4500);
  opacity:0;transition:opacity .3s;
}
.btn-orange span{position:relative;z-index:1;display:inline-flex;align-items:center;gap:8px;}
.btn-orange:hover::before{opacity:1;}
.btn-orange:hover{transform:translateY(-2px);box-shadow:0 12px 32px rgba(255,92,0,.4);}
.btn-orange:active,.btn-dark:active{transform:translateY(0);}
.btn-lg{padding:15px 32px;font-size:15px;border-radius:12px;}

/* magnetic wrapper */
.magnetic{display:inline-block;transition:transform .2s ease;}

/* Navigation signed-out container */
.nav-signed-out{display:flex;align-items:center;gap:12px;}
.nav-signed-in{display:flex;align-items:center;gap:10px;}

/* Navigation dark button variant */
.btn-nav-dark{
  background:var(--ink);color:var(--white);
  position:relative;
  box-shadow:0 4px 16px rgba(0,0,0,.15);
}
.btn-nav-dark span{position:relative;z-index:1;display:inline-flex;align-items:center;gap:8px;}
.btn-nav-dark::before{
  content:'';position:absolute;inset:0;border-radius:inherit;
  background:var(--orange);
  opacity:0;transition:opacity .3s;
}
.btn-nav-dark:hover::before,.btn-nav-dark.active::before{opacity:1;}
.btn-nav-dark:hover,.btn-nav-dark.active{
  transform:translateY(-2px);
  box-shadow:0 12px 32px rgba(255,92,0,.4);
}

/* ════ MOBILE MENU ════ */
.mob-toggle{
  display:none;background:none;border:none;
  font-size:28px;color:var(--ink);
  width:44px;height:44px;padding:0;
  align-items:center;justify-content:center;
  cursor:pointer;border-radius:10px;
  flex-shrink:0;line-height:1;
}
.mob-toggle:hover{background:var(--gray-100);}
.mob-menu{position:fixed;top:0;right:0;width:300px;max-width:88vw;height:100vh;background:var(--white);z-index:2000;padding:80px 28px 28px;transform:translateX(100%);visibility:hidden;transition:transform .3s ease, visibility 0s linear .3s;border-left:1px solid var(--gray-200);box-shadow:var(--shadow-lg);overflow-y:auto;}
.mob-menu.open{transform:translateX(0);visibility:visible;transition:transform .3s ease, visibility 0s linear 0s;}
.mob-close{position:absolute;top:20px;right:20px;background:none;border:none;font-size:22px;color:var(--ink);cursor:pointer;}
.mob-overlay{position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:1999;opacity:0;pointer-events:none;transition:opacity .3s;}
.mob-overlay.open{opacity:1;pointer-events:auto;}
.mob-menu a{display:block;color:var(--gray-600);font-size:16px;font-weight:600;padding:14px 0;}

/* ════ USER DROPDOWN MENU ════ */
.user-dropdown{
  position:absolute;top:calc(100% + 12px);right:0;
  width:260px;
  background:var(--white);
  border:1px solid var(--gray-200);
  border-radius:16px;
  box-shadow:0 24px 64px rgba(0,0,0,.10),0 8px 16px rgba(0,0,0,.04);
  z-index:200;
  opacity:0;pointer-events:none;
  transform:translateY(-8px);
  transition:opacity .25s ease,transform .25s ease;
  overflow:hidden;
}
.user-dropdown.open{opacity:1;pointer-events:auto;transform:translateY(0);}

.ud-header{
  display:flex;align-items:center;gap:12px;
  padding:20px 20px 16px;
  border-bottom:1px solid var(--gray-100);
}
.ud-avatar{width:42px;height:42px;border-radius:50%;object-fit:cover;}
.ud-name{display:block;font-size:14px;font-weight:700;color:var(--ink);}
.ud-email{display:block;font-size:12px;color:var(--gray-400);}

.ud-links{padding:8px 8px 4px;}
.ud-link{
  display:flex;align-items:center;gap:10px;
  padding:9px 12px;border-radius:10px;
  font-size:13.5px;font-weight:600;color:var(--gray-600);
  transition:background .15s,color .15s;
}
.ud-link i{width:18px;text-align:center;color:var(--gray-400);transition:color .15s;}
.ud-link:hover{background:var(--orange-bg);color:var(--orange);}
.ud-link:hover i{color:var(--orange);}

.ud-footer{padding:8px;border-top:1px solid var(--gray-100);}
.ud-logout{
  display:flex;align-items:center;gap:10px;
  width:100%;padding:9px 12px;border:none;background:none;
  border-radius:10px;font-size:13.5px;font-weight:600;
  color:var(--gray-500);font-family:inherit;cursor:pointer;
  transition:background .15s,color .15s;
}
.ud-logout i{width:18px;text-align:center;color:var(--gray-400);transition:color .15s;}
.ud-logout:hover{background:#fef2f2;color:#dc2626;}
.ud-logout:hover i{color:#dc2626;}

/* User avatar wrapper */
.user-avatar-wrapper{position:relative;}

/* User avatar button */
.user-avatar-btn{
  display:flex;align-items:center;gap:8px;
  background:none;border:none;
  padding:6px 8px 6px 6px;
  border-radius:30px;
  cursor:pointer;
  transition:background .2s;
}
.user-avatar-btn:hover{background:var(--gray-100);}
.user-avatar-btn .avatar{
  width:32px;height:32px;border-radius:50%;
  background:var(--orange);
  display:flex;align-items:center;justify-content:center;
  font-size:13px;font-weight:700;color:var(--white);
}
.user-avatar-btn .user-name{font-size:13px;font-weight:600;color:var(--ink);}
.user-avatar-btn .caret{font-size:10px;color:var(--gray-400);transition:transform .2s;}
.user-avatar-btn.open .caret{transform:rotate(180deg);}

/* User avatar img */
.user-avatar-img{
  width:38px;height:38px;border-radius:50%;object-fit:cover;
  border:2px solid var(--gray-200);transition:border-color .2s;
}
.user-avatar-btn:hover .user-avatar-img{border-color:var(--orange);}

/* User avatar caret */
.user-avatar-caret{
  font-size:11px;color:var(--gray-500);
  margin-right:4px;
  transition:transform .2s ease, color .2s;
}
.user-avatar-btn:hover .user-avatar-caret{color:var(--gray-900);}
.user-avatar-wrapper.open .user-avatar-caret{transform:rotate(180deg);color:var(--orange);}

/* User plan badge */
.user-plan-badge{
  font-size:10px;font-weight:700;letter-spacing:.5px;
  text-transform:uppercase;
  background:var(--orange-bg);color:var(--orange);
  padding:3px 8px;border-radius:100px;
  border:1px solid rgba(255,92,0,.2);
}

/* User avatar name */
.user-avatar-name{
  font-size:14px;font-weight:600;color:var(--gray-900);
  max-width:120px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
  padding-left:2px;
}

@media(hover:none){ .user-avatar-btn{cursor:pointer;} }
