/* ===== Global ===== */
body,.pkp_structure_page{font-family:'Inter',sans-serif!important;background:#f8fafc!important;color:#334155}
body{border-top:none!important}
.pkp_structure_page{border-top:none!important;margin-top:0!important}
.pkp_structure_content{max-width:100%!important;padding:0!important;width:100%!important;margin:0!important}
.pkp_structure_main{max-width:100%!important;margin:0 auto!important;padding:0!important;width:100%!important}
.site-content{max-width:100%!important;padding:0!important;width:100%!important}

/* ===== Hide Old OJS Header (Removed to show global header) ===== */

/* ===== Modern Header ===== */
.modern-header{background:#fff;border-bottom:1px solid #e2e8f0;position:sticky;top:0;z-index:1000;box-shadow:0 1px 3px rgba(0,0,0,0.04)}
.modern-header-inner{max-width:1320px;margin:0 auto;padding:0 40px;display:flex;align-items:center;justify-content:space-between;height:72px}
.header-brand{display:flex;align-items:center;gap:14px;text-decoration:none}
.header-brand img{height:42px;width:auto}
.header-brand-text h1{margin:0;font-size:1.25rem;font-weight:800;color:#0f172a;line-height:1.2;letter-spacing:-0.02em}
.header-brand-text p{margin:0;font-size:0.8rem;color:#64748b;font-weight:500}
.header-nav{display:flex;align-items:center;gap:8px}
.header-nav a{color:#475569;font-weight:600;font-size:0.93rem;padding:8px 18px;border-radius:8px;text-decoration:none;transition:all .2s;display:flex;align-items:center;gap:6px}
.header-nav a:hover,.header-nav a.active{color:#4f46e5;background:#f0f0ff}
.header-actions{display:flex;align-items:center;gap:12px}
.header-icon-btn{width:40px;height:40px;border-radius:10px;border:1px solid #e2e8f0;background:#fff;display:flex;align-items:center;justify-content:center;color:#475569;cursor:pointer;transition:all .2s}
.header-icon-btn:hover{border-color:#c7d2fe;color:#4f46e5;background:#f5f3ff}
.btn-masuk{padding:10px 22px;background:linear-gradient(135deg,#4f46e5,#6366f1);color:#fff!important;border-radius:10px;font-weight:700;font-size:0.9rem;text-decoration:none;display:flex;align-items:center;gap:6px;transition:all .25s;box-shadow:0 4px 14px rgba(79,70,229,0.25)}
.btn-masuk:hover{transform:translateY(-2px);box-shadow:0 6px 20px rgba(79,70,229,0.35);color:#fff}

/* ===== Hero ===== */
.hero-section{background:linear-gradient(135deg,#e0e7ff 0%,#ede9fe 50%,#f3e8ff 100%);border-radius:0 0 32px 32px;padding:60px 0 50px;position:relative;overflow:hidden}
.hero-section::before{content:'';position:absolute;top:-60px;right:-60px;width:300px;height:300px;background:rgba(129,140,248,0.15);border-radius:50%;filter:blur(60px)}
.hero-section::after{content:'';position:absolute;bottom:-40px;left:-40px;width:200px;height:200px;background:rgba(167,139,250,0.15);border-radius:50%;filter:blur(50px)}
.hero-inner{max-width:1320px;margin:0 auto;padding:0 40px;display:flex;align-items:center;gap:60px;position:relative;z-index:1}
.hero-content{flex:1;max-width:620px}
.hero-badge{background:linear-gradient(135deg,#4f46e5,#7c3aed);color:#fff;padding:7px 18px;border-radius:20px;font-weight:600;font-size:0.85rem;display:inline-block;margin-bottom:20px}
.hero-title{font-size:3.2rem;font-weight:800;color:#0f172a;margin:0 0 18px;line-height:1.15;letter-spacing:-0.03em}
.hero-desc{font-size:1.05rem;color:#475569;margin-bottom:30px;line-height:1.7;max-width:540px}
.hero-search{display:flex;align-items:center;background:#fff;border-radius:14px;padding:6px;box-shadow:0 8px 30px rgba(0,0,0,0.08);margin-bottom:36px;max-width:520px}
.hero-search input{flex:1;border:none;padding:14px 18px;font-size:0.95rem;font-family:'Inter',sans-serif;color:#334155;outline:none;background:transparent;border-radius:10px}
.hero-search input::placeholder{color:#94a3b8}
.hero-search .search-icon{padding:0 12px;color:#94a3b8;display:flex;align-items:center}
.hero-search button{padding:12px 28px;background:linear-gradient(135deg,#4f46e5,#6366f1);color:#fff;border:none;border-radius:10px;font-weight:700;font-size:0.9rem;cursor:pointer;font-family:'Inter',sans-serif;transition:all .25s}
.hero-search button:hover{background:linear-gradient(135deg,#4338ca,#4f46e5)}
.hero-stats{display:flex;gap:14px;flex-wrap:wrap}
.stat-card{background:#fff;border-radius:14px;padding:12px 18px;display:flex;align-items:center;gap:12px;box-shadow:0 4px 16px rgba(0,0,0,0.04);transition:transform .2s}
.stat-card:hover{transform:translateY(-2px)}
.stat-icon{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:1.1rem}
.stat-icon.blue{background:#dbeafe;color:#2563eb}
.stat-icon.green{background:#dcfce7;color:#16a34a}
.stat-icon.orange{background:#fef3c7;color:#d97706}
.stat-icon.purple{background:#ede9fe;color:#7c3aed}
.stat-text h4{margin:0;font-size:0.9rem;font-weight:700;color:#1e293b}
.stat-text p{margin:0;font-size:0.73rem;color:#64748b}
.hero-image-container{flex:1;display:flex;justify-content:center;align-items:center;position:relative}
.hero-image-container img{max-width:100%;height:auto;max-height:380px;filter:drop-shadow(0 20px 40px rgba(0,0,0,0.12))}
.hero-float-card{position:absolute;background:#fff;border-radius:14px;padding:14px 20px;box-shadow:0 8px 24px rgba(0,0,0,0.1);display:flex;align-items:center;gap:10px}
.hero-float-card.top{top:10px;right:-10px}
.hero-float-card.bottom{bottom:20px;left:-10px}
.float-dot{width:10px;height:10px;border-radius:50%}
.float-number{font-size:1.8rem;font-weight:800;color:#0f172a;line-height:1}
.float-label{font-size:0.75rem;color:#64748b;font-weight:500}

/* ===== Content Wrapper ===== */
.page-content-wrapper{max-width:1320px;margin:0 auto;padding:0 40px}

/* ===== Section Header ===== */
.section-header{display:flex;justify-content:space-between;align-items:flex-end;margin-top:64px;margin-bottom:32px}
.section-title-wrap{display:flex;gap:14px;align-items:center}
.section-icon{background:#ede9fe;color:#4f46e5;width:46px;height:46px;border-radius:12px;display:flex;align-items:center;justify-content:center}
.section-title h2{display:block!important;margin:0;font-size:1.4rem;font-weight:800;color:#0f172a;letter-spacing:-0.01em}
.section-title p{margin:2px 0 0;color:#64748b;font-size:0.9rem}
.section-controls{display:flex;gap:10px;align-items:center}
.filter-select{padding:10px 36px 10px 14px;border-radius:10px;border:1px solid #e2e8f0;background:#fff;font-family:'Inter',sans-serif;font-size:0.9rem;color:#475569;font-weight:500;cursor:pointer;appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2394a3b8' stroke-width='2'%3e%3cpath d='m6 9 6 6 6-6'/%3e%3c/svg%3e");background-repeat:no-repeat;background-position:right 12px center;outline:none;min-width:180px}
.filter-select:focus{border-color:#4f46e5}
.btn-icon{width:42px;height:42px;border-radius:10px;border:1px solid #e2e8f0;background:#fff;display:flex;align-items:center;justify-content:center;color:#475569;cursor:pointer;transition:all .2s}
.btn-icon.active{border-color:#4f46e5;color:#4f46e5;background:#f5f3ff}

/* Hide old default heading */
.journals > h2:first-of-type{display:none!important}

/* ===== Journal Grid ===== */
.journals-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-bottom:40px}
.journal-card{background:#fff;border-radius:20px;overflow:hidden;box-shadow:0 4px 16px rgba(0,0,0,0.04);display:flex;flex-direction:column;transition:transform .35s ease,box-shadow .35s ease;border:1px solid #f1f5f9}
.journal-card:hover{transform:translateY(-6px);box-shadow:0 16px 40px rgba(0,0,0,0.08)}
.journal-cover-top{position:relative;height:180px;overflow:hidden;background:#f1f5f9}
.journal-cover-top img{width:100%;height:100%;object-fit:cover;transition:transform .4s ease}
.journal-card:hover .journal-cover-top img{transform:scale(1.05)}
.journal-badge{position:absolute;top:12px;left:12px;padding:4px 12px;border-radius:6px;font-weight:700;font-size:0.7rem;letter-spacing:0.03em;text-transform:uppercase;color:#fff}
.journal-badge.green{background:#22c55e}
.journal-badge.yellow{background:#eab308}
.journal-badge.blue{background:#3b82f6}
.journal-badge.purple{background:#8b5cf6}
.journal-card-body{padding:18px;flex:1;display:flex;flex-direction:column}
.journal-title{font-size:0.95rem;font-weight:700;color:#0f172a;margin:0 0 8px;line-height:1.35;text-decoration:none;display:block;letter-spacing:-0.01em}
.journal-title:hover{color:#4f46e5}
.journal-desc{font-size:0.82rem;color:#64748b;line-height:1.5;margin:0 0 16px;flex:1}
.journal-actions{display:flex;gap:8px;margin-top:auto}
.btn-outline{flex:1;display:flex;align-items:center;justify-content:center;gap:5px;padding:9px 6px;border:1px solid #e2e8f0;border-radius:8px;color:#4f46e5;font-weight:600;font-size:0.78rem;text-decoration:none;transition:all .2s;background:transparent}
.btn-outline:hover{background:#f5f3ff;border-color:#c7d2fe;color:#4f46e5}
.btn-solid{flex:1;display:flex;align-items:center;justify-content:center;gap:5px;padding:9px 6px;background:linear-gradient(135deg,#4f46e5,#6366f1);color:#fff;border-radius:8px;font-weight:600;font-size:0.78rem;text-decoration:none;box-shadow:0 4px 12px rgba(79,70,229,0.25);transition:all .2s}
.btn-solid:hover{transform:translateY(-1px);color:#fff;box-shadow:0 6px 16px rgba(79,70,229,0.35)}

/* ===== Why Section ===== */
.why-section{margin-top:64px;text-align:center}
.why-section h2{font-size:1.5rem;font-weight:800;color:#0f172a;margin:0 0 12px}
.why-section>p{color:#64748b;margin:0 0 40px;font-size:0.95rem}
.why-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.why-card{background:#fff;border-radius:20px;padding:32px 24px;text-align:center;box-shadow:0 4px 16px rgba(0,0,0,0.03);border:1px solid #f1f5f9;transition:transform .3s,box-shadow .3s}
.why-card:hover{transform:translateY(-4px);box-shadow:0 12px 32px rgba(0,0,0,0.06)}
.why-icon{width:64px;height:64px;border-radius:16px;margin:0 auto 18px;display:flex;align-items:center;justify-content:center;font-size:1.5rem}
.why-icon.i1{background:#ede9fe;color:#7c3aed}
.why-icon.i2{background:#fce7f3;color:#ec4899}
.why-icon.i3{background:#dbeafe;color:#2563eb}
.why-icon.i4{background:#dcfce7;color:#16a34a}
.why-card h3{font-size:1rem;font-weight:700;color:#0f172a;margin:0 0 8px}
.why-card p{font-size:0.85rem;color:#64748b;line-height:1.5;margin:0}

/* ===== CTA Banner ===== */
.cta-section{margin-top:64px;background:linear-gradient(135deg,#4f46e5,#7c3aed);border-radius:24px;padding:48px 56px;display:flex;align-items:center;justify-content:space-between;position:relative;overflow:hidden}
.cta-section::before{content:'';position:absolute;top:-30px;right:80px;width:200px;height:200px;background:rgba(255,255,255,0.08);border-radius:50%}
.cta-section::after{content:'';position:absolute;bottom:-40px;left:120px;width:160px;height:160px;background:rgba(255,255,255,0.06);border-radius:50%}
.cta-text{position:relative;z-index:1}
.cta-text h2{color:#fff;font-size:1.6rem;font-weight:800;margin:0 0 10px}
.cta-text p{color:rgba(255,255,255,0.85);font-size:1rem;margin:0;max-width:480px}
.btn-cta{position:relative;z-index:1;padding:14px 28px;background:#fff;color:#4f46e5;border-radius:12px;font-weight:700;font-size:0.95rem;text-decoration:none;display:flex;align-items:center;gap:8px;transition:all .25s;box-shadow:0 4px 16px rgba(0,0,0,0.15);white-space:nowrap}
.btn-cta:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,0.2);color:#4f46e5}

/* ===== Footer ===== */
.modern-footer{background:#ffffff;padding:56px 0 0;margin-top:64px;border-top:1px solid #e2e8f0;box-shadow:0 -4px 6px -1px rgba(0,0,0,0.05), 0 -2px 4px -1px rgba(0,0,0,0.03)}
.footer-inner{max-width:1320px;margin:0 auto;padding:0 40px;display:grid;grid-template-columns:1.5fr 1fr 1fr 1.2fr 1.4fr;gap:36px}
.footer-brand h3{color:#1e293b;font-size:1.15rem;font-weight:700;margin:0 0 6px}
.footer-brand .subtitle{color:#64748b;font-size:0.82rem;margin:0 0 14px}
.footer-brand .desc{color:#475569;font-size:0.8rem;line-height:1.6;margin:0 0 18px}
.social-links{display:flex;gap:10px}
.social-links a{width:34px;height:34px;border-radius:8px;background:#f1f5f9;color:#64748b;display:flex;align-items:center;justify-content:center;transition:all .2s;text-decoration:none}
.social-links a:hover{background:#4f46e5;color:#fff}
.footer-col h4{color:#1e293b;font-size:0.9rem;font-weight:700;margin:0 0 18px}
.footer-col ul{list-style:none;margin:0;padding:0}
.footer-col li{margin-bottom:10px}
.footer-col a{color:#475569;font-size:0.83rem;text-decoration:none;transition:color .2s}
.footer-col a:hover{color:#4f46e5}
.footer-contact li{display:flex;gap:10px;align-items:flex-start;color:#475569;font-size:0.83rem;margin-bottom:12px}
.footer-contact svg{flex-shrink:0;margin-top:2px;color:#64748b}
.footer-newsletter h4{color:#1e293b;font-size:0.9rem;font-weight:700;margin:0 0 8px}
.footer-newsletter p{color:#475569;font-size:0.8rem;margin:0 0 16px;line-height:1.5}
.newsletter-form{display:flex;gap:0;background:#f8fafc;border-radius:10px;overflow:hidden;border:1px solid #cbd5e1}
.newsletter-form input{flex:1;border:none;background:transparent;padding:12px 14px;color:#1e293b;font-size:0.85rem;font-family:'Inter',sans-serif;outline:none}
.newsletter-form input::placeholder{color:#94a3b8}
.newsletter-form button{background:#4f46e5;color:#fff;border:none;padding:12px 16px;cursor:pointer;transition:background .2s;display:flex;align-items:center}
.newsletter-form button:hover{background:#4338ca}
.footer-bottom{border-top:1px solid #e2e8f0;margin-top:40px;padding:20px 40px;text-align:center;max-width:1320px;margin-left:auto;margin-right:auto}
.footer-bottom p{color:#64748b;font-size:0.8rem;margin:0}

/* ===== Responsive ===== */
@media(max-width:1200px){
.journals-grid,.why-grid{grid-template-columns:repeat(2,1fr)}
.footer-inner{grid-template-columns:repeat(3,1fr)}
.hero-stats{flex-wrap:wrap}
.cta-section{flex-direction:column;text-align:center;padding:40px 32px;gap:24px}
}
@media(max-width:768px){
.modern-header-inner{padding:0 20px;height:64px}
.header-nav{display:none}
.hero-section{padding:40px 0 30px}
.hero-inner{flex-direction:column;padding:0 20px;gap:30px;text-align:center}
.hero-title{font-size:2.2rem}
.hero-search{max-width:100%}
.hero-stats{justify-content:center}
.hero-image-container{max-width:300px}
.page-content-wrapper{padding:0 20px}
.journals-grid,.why-grid{grid-template-columns:1fr}
.footer-inner{grid-template-columns:1fr;gap:28px}
.section-header{flex-direction:column;align-items:flex-start;gap:16px}
}

/* Hide vertical divider lines from OJS theme layout */
.pkp_structure_main:before,
.pkp_structure_main:after {
    display: none !important;
}

/* Custom Branded Blue Header */
.custom-auth-header {
    background: #003595 !important;
    padding: 14px 40px !important;
    display: flex !important;
    justify-content: center !important;
    align-items: center !important;
    box-shadow: 0 4px 12px rgba(0,0,0,0.06) !important;
    width: 100% !important;
    box-sizing: border-box !important;
    position: sticky !important;
    top: 0 !important;
    z-index: 1000 !important;
}
.custom-header-container {
    width: 100% !important;
    max-width: 1300px !important;
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
}
.custom-header-left {
    display: flex !important;
    align-items: center !important;
    gap: 14px !important;
}
.custom-header-logo {
    height: 40px !important;
    width: auto !important;
}
.custom-header-title-group {
    display: flex !important;
    flex-direction: column !important;
}
.custom-header-title {
    font-size: 1.2rem !important;
    font-weight: 800 !important;
    color: #ffffff !important;
    line-height: 1.2 !important;
    letter-spacing: -0.01em !important;
}
.custom-header-subtitle {
    font-size: 0.75rem !important;
    color: rgba(255, 255, 255, 0.85) !important;
    font-weight: 500 !important;
}
.custom-header-middle {
    display: flex !important;
    align-items: center !important;
    gap: 24px !important;
}
.custom-header-right {
    display: flex !important;
    align-items: center !important;
    gap: 24px !important;
}
.custom-header-link {
    color: rgba(255, 255, 255, 0.9) !important;
    text-decoration: none !important;
    font-weight: 600 !important;
    font-size: 0.9rem !important;
    display: flex !important;
    align-items: center !important;
    gap: 8px !important;
    transition: color 0.2s ease !important;
}
.custom-header-link:hover, .custom-header-link.active {
    color: #ffffff !important;
}

