/*
Theme Name: PSPSF Research Center Theme
Theme URI: https://pspsf.farmasi.unpad.ac.id
Author: OpenAI for PSPSF
Description: Custom bilingual WordPress theme for Pusat Studi Pengembangan Sediaan Farmasi (PSPSF), Faculty of Pharmacy, Universitas Padjadjaran.
Version: 1.0.0
License: GNU General Public License v2 or later
Text Domain: pspsf
*/
:root{--blue:#1e6f9f;--teal:#39b5c8;--gold:#f4b400;--dark:#222;--muted:#5c6b73;--bg:#f8fafc;--card:#fff;--line:#dfe8ee;--max:1180px;--radius:20px}
*{box-sizing:border-box} html{scroll-behavior:smooth} body{margin:0;font-family:Inter,Arial,sans-serif;color:var(--dark);background:var(--bg);line-height:1.65} a{color:var(--blue);text-decoration:none} img{max-width:100%;height:auto}
.container{max-width:var(--max);margin:0 auto;padding:0 20px}.section{padding:72px 0}.section-sm{padding:42px 0}.eyebrow{color:var(--blue);font-weight:700;letter-spacing:.04em;text-transform:uppercase;font-size:.82rem}.section-title{font-size:2rem;line-height:1.2;margin:10px 0 14px}.section-sub{max-width:820px;color:var(--muted)}
.site-header{position:sticky;top:0;z-index:100;background:rgba(255,255,255,.94);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.header-wrap{display:flex;align-items:center;justify-content:space-between;gap:18px;padding:12px 0}.brand{display:flex;align-items:center;gap:14px}.brand img{height:58px}.brand-text{line-height:1.15}.brand-title{font-weight:800;font-size:1rem}.brand-sub{font-size:.82rem;color:var(--muted)}
.nav-toggle{display:none;background:none;border:0;font-size:1.45rem}.main-nav ul{display:flex;gap:22px;list-style:none;margin:0;padding:0}.main-nav a{color:var(--dark);font-weight:600;font-size:.95rem}.lang-switch{display:flex;gap:8px;align-items:center}.lang-switch a{display:inline-block;padding:7px 12px;border:1px solid var(--line);border-radius:999px;color:var(--dark);font-weight:700;font-size:.84rem}.lang-switch a.active{background:var(--blue);color:#fff;border-color:var(--blue)}
.hero{background:radial-gradient(circle at top left, rgba(57,181,200,.18), transparent 28%),linear-gradient(135deg, #fff 0%, #eef7fb 100%);padding:88px 0 70px;overflow:hidden}.hero-grid{display:grid;grid-template-columns:1.25fr .95fr;gap:40px;align-items:center}.hero h1{font-size:3rem;line-height:1.05;margin:14px 0}.hero p{font-size:1.08rem;color:var(--muted);max-width:720px}.cta-row{display:flex;flex-wrap:wrap;gap:14px;margin-top:24px}.btn{display:inline-block;padding:13px 20px;border-radius:999px;font-weight:800}.btn-primary{background:linear-gradient(135deg,var(--blue),var(--teal));color:#fff}.btn-secondary{background:#fff;border:1px solid var(--line);color:var(--dark)}
.hero-card{background:#fff;border:1px solid var(--line);border-radius:28px;padding:26px;box-shadow:0 18px 40px rgba(30,111,159,.10)}.metric-grid,.card-grid,.service-grid,.innovation-grid,.impact-grid,.team-grid{display:grid;gap:22px}.metric-grid{grid-template-columns:repeat(4,1fr);margin-top:30px}.metric{background:#fff;padding:22px;border-radius:22px;border:1px solid var(--line);text-align:center}.metric .num{font-size:2rem;font-weight:900;color:var(--blue)}.metric .label{font-size:.95rem;color:var(--muted)}
.card-grid{grid-template-columns:repeat(4,1fr)}.card,.service-card,.innovation-card,.impact-card,.team-card,.news-card{background:#fff;border:1px solid var(--line);border-radius:22px;padding:24px;box-shadow:0 10px 24px rgba(26,52,75,.04)}.card h3,.service-card h3,.innovation-card h3,.team-card h3{margin:0 0 10px;font-size:1.1rem}.service-grid{grid-template-columns:repeat(3,1fr)}.service-card ul,.innovation-card ul{padding-left:18px;margin:12px 0 0}.service-card li,.innovation-card li{margin:7px 0}.badge{display:inline-block;padding:6px 12px;border-radius:999px;background:rgba(244,180,0,.12);color:#7c5c00;font-size:.8rem;font-weight:800}
.two-col{display:grid;grid-template-columns:1.12fr .88fr;gap:30px;align-items:start}.panel{background:#fff;border:1px solid var(--line);border-radius:24px;padding:28px}.pipeline{display:grid;gap:14px;margin-top:18px}.pipe-step{display:flex;gap:14px;align-items:flex-start;padding:14px 16px;border:1px dashed #b8d7e5;border-radius:18px;background:#fbfdff}.pipe-no{width:34px;height:34px;display:grid;place-items:center;border-radius:50%;background:linear-gradient(135deg,var(--blue),var(--teal));color:#fff;font-weight:800;flex-shrink:0}
.innovation-grid{grid-template-columns:repeat(3,1fr)}.impact-grid{grid-template-columns:repeat(3,1fr)}.team-grid{grid-template-columns:repeat(3,1fr)}
.news-list{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}.news-card .meta{font-size:.82rem;color:var(--muted);margin-bottom:8px}.news-card h3{margin:0 0 8px;font-size:1.06rem}
.footer{background:#0d2340;color:#dbe7f1;padding:50px 0 24px;margin-top:50px}.footer-grid{display:grid;grid-template-columns:1.2fr 1fr 1fr;gap:24px}.footer a{color:#fff}.footer .brand img{height:64px}.copyright{border-top:1px solid rgba(255,255,255,.15);margin-top:24px;padding-top:14px;font-size:.9rem;color:#b5cad8}
.page-hero{padding:56px 0;background:linear-gradient(135deg,#eef7fb,#fff)}.content-narrow{max-width:900px}.table-like{display:grid;gap:16px}.mini-title{font-size:1.3rem;margin-top:0}.icon-list{display:grid;gap:12px}.icon-list li{list-style:none;padding:14px 16px;border:1px solid var(--line);border-radius:16px;background:#fff}.kpi-row{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}.kpi{background:#fff;border:1px solid var(--line);padding:18px;border-radius:18px;text-align:center}
@media (max-width: 1080px){.hero-grid,.two-col{grid-template-columns:1fr}.metric-grid,.card-grid,.innovation-grid,.impact-grid,.team-grid,.news-list{grid-template-columns:repeat(2,1fr)}.service-grid{grid-template-columns:1fr}.footer-grid{grid-template-columns:1fr 1fr}.main-nav ul{gap:14px}}
@media (max-width: 760px){.nav-toggle{display:block}.main-nav{display:none;position:absolute;left:0;right:0;top:82px;background:#fff;border-bottom:1px solid var(--line)}.main-nav.open{display:block}.main-nav ul{display:block;padding:14px 20px}.main-nav li{margin:10px 0}.brand img{height:48px}.hero h1{font-size:2.2rem}.metric-grid,.card-grid,.innovation-grid,.impact-grid,.team-grid,.news-list,.kpi-row{grid-template-columns:1fr}.footer-grid{grid-template-columns:1fr}.lang-switch{display:none}.header-wrap{align-items:flex-start}}
