/*
Theme Name: GeneratePress Child - Bank Portal
Template: generatepress
Version: 1.0.0
*/

/* =========================================================
   LOCAL FONTS (self-hosted)
   Folder:
   /wp-content/themes/generatepress-child/fonts/
   ========================================================= */


/* Hussar (bold only) — woff2 first, then woff fallback */
@font-face{
  font-family: "Hussar";
  src:
    url("fonts/HussarBold2.woff2") format("woff2"),
    url("fonts/HussarBold.woff") format("woff");
  font-weight: 700;
  font-style: normal;
  font-display: swap;
}

/* =========================================================
   THEME VARIABLES
   ========================================================= */
:root{
  --bg:#f6f7fb;
  --panel:#ffffff;
  --text:#0f172a;
  --muted:#64748b;
  --border:#e5e7eb;
  --primary:#0a4ea1;
  --shadow: 0 10px 30px rgba(15,23,42,.08);

  --success:#16a34a;
  --danger:#dc2626;
  --warning:#f59e0b;
  --accent:#16B8A6;
}
:root[data-theme="dark"]{
  --bg:#0b1220;
  --panel:#0f1b33;
  --text:#e5e7eb;
  --muted:#94a3b8;
  --border:#1f2a44;
  --primary:#6aa7ff;
  --shadow: 0 10px 30px rgba(0,0,0,.35);

  --success:#16a34a;
  --danger:#dc2626;
  --warning:#f59e0b;
  --accent:#16B8A6;
}

/* =========================================================
   GLOBAL TYPOGRAPHY
   ========================================================= */
body{
  font-family: "Recia", Inter, "Helvetica Neue", Helvetica, Roboto, "Open Sans", Lato, Montserrat, Arial, sans-serif !important;
  background: var(--bg);
  color: var(--text);
}
h1,h2,h3{
  font-family: "Hussar", "Recia", Inter, "Helvetica Neue", Helvetica, Arial, sans-serif;
  font-weight: 700;
}

/* =========================================================
   BANK PORTAL LAYOUT (your original)
   ========================================================= */
.dbp-shell{display:flex; min-height: calc(100vh - 80px); gap:16px; padding:16px;}
.dbp-sidebar{width:260px; background:var(--panel); border:1px solid var(--border); border-radius:16px; box-shadow:var(--shadow); padding:14px; position:sticky; top:16px; height: fit-content;}
.dbp-main{flex:1; min-width:0;}
.dbp-topbar{display:flex; align-items:center; justify-content:space-between; gap:12px; margin-bottom:16px;}
.dbp-card{background:var(--panel); border:1px solid var(--border); border-radius:16px; box-shadow:var(--shadow); padding:16px;}
.dbp-grid{display:grid; grid-template-columns: repeat(12, 1fr); gap:16px;}
.dbp-col-6{grid-column: span 6;}
.dbp-col-12{grid-column: span 12;}
.dbp-nav a{display:block; padding:10px 12px; border-radius:12px; color:var(--text); text-decoration:none;}
.dbp-nav a:hover{background:rgba(10,78,161,.08);}
.dbp-badge{font-size:12px; color:var(--muted);}
.dbp-btn{display:inline-flex; align-items:center; justify-content:center; gap:8px; padding:10px 12px; border-radius:12px; border:1px solid var(--border); background:var(--panel); color:var(--text); text-decoration:none; cursor:pointer;}
.dbp-btn--primary{background: linear-gradient(135deg, var(--primary), var(--accent)); border:0; color:#fff;}
.dbp-table{width:100%; border-collapse:separate; border-spacing:0;}
.dbp-table th,.dbp-table td{padding:10px 12px; border-bottom:1px solid var(--border); text-align:left;}
.dbp-amt-pos{color:var(--success);}
.dbp-amt-neg{color:var(--danger);}
.dbp-kpi{display:flex;justify-content:space-between;align-items:flex-end;gap:10px;}
.dbp-kpi .value{font-size:34px;font-weight:900;}
.dbp-pill{display:inline-flex;align-items:center;padding:6px 10px;border-radius:999px;border:1px solid var(--border);background:var(--panel);}
@media (max-width: 980px){
  .dbp-shell{flex-direction:column;}
  .dbp-sidebar{width:auto; position:relative; top:auto;}
  .dbp-col-6{grid-column: span 12;}
}

/* =========================================================
   UEB HOMEPAGE SECTION (FULL BLOCK - COPY/PASTE)
   Works best when Home page Content Container = Full Width
   ========================================================= */

/* --- UEB --- */
.ueb-wrap, .ueb-wrap *{ box-sizing:border-box; }

.ueb-wrap{
  width: 100%;
  margin: 0;
  padding: 0;
}

.ueb-surface{
  width: 100%;
  margin: 0;
  border-radius: 0;
  padding: 14px 16px;

  background:
    radial-gradient(900px 520px at 10% 0%, rgba(96,165,250,.30), transparent 60%),
    radial-gradient(900px 520px at 90% 10%, rgba(29,78,216,.26), transparent 62%),
    linear-gradient(180deg, #072a74 0%, #0b3aa6 34%, #eef4ff 100%);
}

/* Desktop “card” look (optional) */
@media (min-width: 981px){
  .ueb-surface{
    width: 100%;
    max-width: none;
    margin: 0;
    border-radius: 0;
    padding: 16px 18px;
  }
}


.ueb-headline{
  color:#fff !important;
  font-size: clamp(18px, 5vw, 32px);
  font-weight: 520;
  line-height: 1.15;
  margin: 6px 0 10px;
  text-align:center;
}

.ueb-quotes{
  margin: 0 0 10px;
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
}
@media (max-width: 980px){
  .ueb-quotes{ grid-template-columns: 1fr; }
}

.ueb-quote{
  border-radius: 14px;
  border:1px solid rgba(255,255,255,.20);
  background: rgba(255,255,255,.12);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  padding: 10px 12px;
  color: rgba(255,255,255,.92);
}
.ueb-quote b{
  display:block;
  color:#16B8A6 !important;
  font-size: 11px;
  font-weight: 750;
  letter-spacing: .14em;
  text-transform: uppercase;
  margin-bottom: 6px;
}
.ueb-quote p{ margin:0; font-size:12.5px; line-height:1.45; }

.ueb-tiles{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
}
@media (max-width: 980px){
  .ueb-tiles{ grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 640px){
  .ueb-tiles{ grid-template-columns: 1fr; }
}

.ueb-tile{
  border-radius:16px;
  overflow:hidden;
  background: rgba(255,255,255,.92);
  border: 1px solid rgba(255,255,255,.22);
  box-shadow: 0 18px 55px rgba(7,16,34,.18);
}

.ueb-wrap .ueb-tile figure,
.ueb-wrap .ueb-tile .wp-block-image,
.ueb-wrap .ueb-tile a,
.ueb-wrap .ueb-tile picture{
  display:block !important;
  width:100% !important;
  max-width:none !important;
  margin:0 !important;
  padding:0 !important;
}

.ueb-wrap .ueb-tile img,
.ueb-wrap img.ueb-tileImg{
  display:block !important;
  width:100% !important;
  max-width:none !important;
  height: 210px !important;
  object-fit: cover !important;
  margin:0 !important;
  float:none !important;
}
@media (max-width: 640px){
  .ueb-wrap .ueb-tile img,
  .ueb-wrap img.ueb-tileImg{
    height: 230px !important;
  }
}

.ueb-cap{
  background:#072a74;
  color:#fff;
  padding:12px 14px;
  min-height:118px;
  display:flex;
  flex-direction:column;
  justify-content:space-between;
  gap:10px;
}

.ueb-cap h3{
  margin:0;
  color:#fff !important;
  font-size: 20px;
  font-weight: 560;
  line-height: 1.15;
}
.ueb-cap p{
  margin:0;
  color: rgba(255,255,255,.88) !important;
  font-size: 13px;
  line-height: 1.45;
  max-width: 48ch;
}

.ueb-cta{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width: 180px;
  max-width: 100%;
  padding: 9px 11px;
  border-radius: 12px;
  background: rgba(255,255,255,.10);
  border: 1px solid rgba(255,255,255,.28);
  color:#fff !important;
  font-weight: 850;
  font-size: 12.5px;
  text-decoration:none;
}
.ueb-cta:hover{ background: rgba(255,255,255,.16); }

.ueb-legal{
  margin-top: 12px;
  padding: 12px 14px;
  border-radius: 14px;
  background: rgba(255,255,255,.92);
  border: 1px solid rgba(15,23,42,.10);
  color: #0f172a;
  font-size: 12px;
  line-height: 1.5;
}
.ueb-legal b{ font-weight: 800; }
.ueb-legal a{ color: #0a4ea1; text-decoration: underline; }

/* --- GeneratePress full-width fixes --- */

/* Remove theme content padding on Full Width pages */
.full-width-content.separate-containers .inside-article,
.full-width-content.one-container .site-content{
  padding-left: 0 !important;
  padding-right: 0 !important;
}

/* Force main container to 100% when page is not "contained" */
body:not(.contained-content) .container.grid-container{
  max-width: 100% !important;
}


/* Remove side padding in the main content area */
.full-width-content.separate-containers .inside-article,
.full-width-content.one-container .site-content{
  padding-left: 0 !important;
  padding-right: 0 !important;
}

/* Make Gutenberg/GenerateBlocks full-width blocks actually full width */
.alignfull{
  width: 100vw;
  max-width: 100vw;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
}
/* =========================================================
   MODERN BANK LOGIN PAGE (Enhanced for 2026 Banking UX)
   ========================================================= */
.dbp-auth{
  min-height: 100vh;
  padding: 20px 16px;
  background:
    linear-gradient(135deg, rgba(7,42,116,.85), rgba(10,78,161,.75)),
    url("https://image2url.com/r2/default/images/1772017315892-91fdd240-77ba-45c0-88f8-649c0573023c.jpg");
  background-size: cover;
  background-position: center;
  background-attachment: fixed;
  display: flex;
  align-items: center;
  justify-content: center;
}

.dbp-auth__wrap{
  max-width: 420px;
  width: 100%;
}

.dbp-auth__card{
  background: rgba(255,255,255,.95);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  border: 1px solid rgba(255,255,255,.25);
  border-radius: 24px;
  box-shadow: 0 25px 60px rgba(0,0,0,.25);
  padding: 48px 32px;
  position: relative;
  overflow: hidden;
}

.dbp-auth__card::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 4px;
  background: linear-gradient(90deg, var(--primary), var(--accent));
}

:root[data-theme="dark"] .dbp-auth__card{
  background: rgba(15,27,51,.95);
  border-color: rgba(255,255,255,.15);
}

.dbp-auth__top{
  text-align: center;
  margin-bottom: 32px;
}

.dbp-auth__title{ 
  margin: 0 0 8px;
  font-size: clamp(24px, 5vw, 32px);
  font-weight: 700;
  background: linear-gradient(135deg, var(--primary), var(--accent));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

.dbp-auth__subtitle {
  color: var(--muted);
  font-size: 15px;
  margin: 0;
}

.dbp-auth__error{
  background: rgba(var(--danger), .1);
  color: var(--danger);
  padding: 12px;
  border-radius: 12px;
  border-left: 4px solid var(--danger);
  margin: 0 0 20px;
  font-size: 14px;
}

.dbp-auth__field{ 
  position: relative; 
  margin-bottom: 24px; 
}

.dbp-auth__field label{
  position: absolute;
  left: 16px;
  top: 16px;
  color: var(--muted);
  font-size: 15px;
  pointer-events: none;
  transition: all .2s ease;
  font-weight: 500;
}

.dbp-auth__field input:focus + label,
.dbp-auth__field input:not(:placeholder-shown) + label {
  top: -8px;
  left: 12px;
  font-size: 12px;
  color: var(--primary);
  background: var(--panel);
  padding: 0 6px;
}

.dbp-auth__field input{
  width: 100%;
  padding: 20px 16px 16px;
  border: 2px solid rgba(101,116,139,.3);
  border-radius: 16px;
  background: rgba(255,255,255,.8);
  color: var(--text);
  font-size: 16px;
  transition: all .2s ease;
  backdrop-filter: blur(10px);
}

.dbp-auth__field input:focus {
  outline: none;
  border-color: var(--primary);
  box-shadow: 0 0 0 4px rgba(10,78,161,.1);
  background: rgba(255,255,255,1);
}

:root[data-theme="dark"] .dbp-auth__field input {
  background: rgba(15,27,51,.8);
  color: var(--text);
}

.dbp-auth__field .password-toggle {
  position: absolute;
  right: 16px;
  top: 50%;
  transform: translateY(-50%);
  background: none;
  border: none;
  color: var(--muted);
  cursor: pointer;
  font-size: 18px;
}

.dbp-auth__submit{ 
  width: 100%; 
  margin: 8px 0 20px;
}

.dbp-auth__hint{ 
  text-align: center; 
  color: var(--muted);
  font-size: 14px;
  margin: 0 0 16px;
}

.dbp-auth__hint a {
  color: var(--primary);
  text-decoration: none;
  font-weight: 600;
}

.dbp-auth__hint a:hover {
  text-decoration: underline;
}

.dbp-auth__security {
  display: flex;
  gap: 12px;
  margin-top: 24px;
  font-size: 12px;
  color: var(--muted);
}

.dbp-auth__security-icon {
  width: 20px;
  height: 20px;
  background: var(--success);
  border-radius: 4px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 12px;
  color: white;
  font-weight: 700;
}

/* Mobile optimization */
@media (max-width: 480px) {
  .dbp-auth {
    padding: 16px;
    background-attachment: scroll;
  }
  .dbp-auth__card {
    padding: 40px 24px;
    margin: 0 8px;
  }
}

/* =========================================================
   Slim bank-style header (laptop/iPad friendly)
   ========================================================= */

/* Reduce overall header height */
@media (min-width: 769px){
  .main-navigation .inside-navigation{
    padding: 8px 12px; /* smaller than typical */
    box-sizing: border-box;
  }
}

/* Smaller menu typography + slimmer hit area (still usable) */
.main-navigation .main-nav ul li a{
  font-size: 13px;
  line-height: 28px;   /* makes the nav bar slimmer */
  padding: 0 10px;     /* horizontal spacing only */
  letter-spacing: .01em;
}

/* Slightly smaller site title/logo text */
.site-branding .site-title a,
.main-title a{
  font-size: 18px;
  letter-spacing: .03em;
}

/* Even tighter on iPad/laptop widths */
@media (max-width: 1200px){
  .main-navigation .main-nav ul li a{
    font-size: 12.5px;
    padding: 0 8px;
  }
  .site-branding .site-title a,
  .main-title a{
    font-size: 17px;
  }
}

/* Mobile: keep toggle compact */
@media (max-width: 768px){
  .menu-toggle{
    padding: 7px 9px;
    border-radius: 10px;
  }
}

/* Site title / logo area */
.site-branding .site-title a,
.main-title a{
  color: #fff !important;
  font-family: "Hussar", "Recia", Inter, "Helvetica Neue", Arial, sans-serif;
  font-weight: 800;
  letter-spacing: .04em;
  text-transform: uppercase;
}

.site-branding .site-description{
  color: rgba(255,255,255,.78);
}

/* Hover + current menu item */
.main-navigation .main-nav ul li a:hover,
.main-navigation .main-nav ul li.current-menu-item > a,
.main-navigation .main-nav ul li.current_page_item > a{
  color: #fff !important;
  background: rgba(255,255,255,.10);
  border-radius: 12px;
}

/* Small accent underline on hover */
@media (min-width: 769px){
  .main-navigation .main-nav ul li a{
    position: relative;
  }
  .main-navigation .main-nav ul li a::after{
    content:"";
    position:absolute;
    left: 14px;
    right: 14px;
    bottom: 8px;
    height: 2px;
    background: linear-gradient(90deg, var(--accent), rgba(255,255,255,.0));
    opacity: 0;
    transform: translateY(3px);
    transition: .2s ease;
  }
  .main-navigation .main-nav ul li a:hover::after,
  .main-navigation .main-nav ul li.current-menu-item > a::after,
  .main-navigation .main-nav ul li.current_page_item > a::after{
    opacity: 1;
    transform: translateY(0);
  }
}

/* Mobile menu button */
.menu-toggle{
  background: rgba(255,255,255,.10);
  border: 1px solid rgba(255,255,255,.18);
  color: #fff !important;
  border-radius: 12px;
}
.menu-toggle:hover{
  background: rgba(255,255,255,.16);
}

/* Dropdown menu */
.main-navigation ul ul{
  background: rgba(7,42,116,.98);
  border: 1px solid rgba(255,255,255,.14);
  border-radius: 14px;
  padding: 8px;
}
.main-navigation ul ul li a{
  padding: 10px 12px;
  border-radius: 10px;
}
.main-navigation ul ul li a:hover{
  background: rgba(255,255,255,.10);
}
/* ===== Restore header/nav color + branding (GP variations) ===== */
#masthead,
.site-header,
#site-navigation,
.main-navigation{
  background: linear-gradient(135deg, #072a74 0%, #0a4ea1 55%, #046371 100%) !important;
  border-bottom: 1px solid rgba(255,255,255,.14);
}

/* Ensure branding/title is visible */
.site-branding,
.site-title,
.main-title{
  display: block !important;
}

.site-title a,
.main-title a{
  color: #fff !important;
}

/* Ensure nav links are visible */
.main-navigation .main-nav ul li a{
  color: rgba(255,255,255,.92) !important;
}
/* Apply on ALL devices */
#masthead, .site-header, #site-navigation, .main-navigation{
  background: linear-gradient(135deg, #072a74 0%, #0a4ea1 55%, #046371 100%) !important;
  border-bottom: 1px solid rgba(255,255,255,.14);
}

.site-title a, .main-title a{ color:#fff !important; }
.main-navigation .main-nav ul li a{ color: rgba(255,255,255,.92) !important; }

/* Sticky only on desktop */
@media (min-width: 769px){
  #masthead, .site-header{
    position: sticky;
    top: 0;
    z-index: 999;
  }
}
