/*!
Theme Name: ITSI – Institut Teknologi Sawit Indonesia
Theme URI: https://itsi.ac.id
Author: ITSI Web Team
Author URI: https://itsi.ac.id
Description: Tema resmi Institut Teknologi Sawit Indonesia. Desain Luxury Blue (deep navy → royal → cerulean) dengan aksen Antique Gold.
Version: 1.0.0
Requires at least: 5.6
Tested up to: 6.4
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: LICENSE
Text Domain: itsi
Tags: custom-background, custom-logo, custom-menu, featured-images, threaded-comments, translation-ready

ITSI Theme — Based on the original Underscores starter, redesigned for ITSI.
*/

/* ═══════════════════════════════════════
   ITSI – DESIGN SYSTEM
   Tema: Luxury Blue — deep navy → royal → cerulean
   Accent: Antique Gold (#BF9B30)
   Font: Cormorant Garamond (serif display) + Plus Jakarta Sans (body)
═══════════════════════════════════════ */

:root {
  /* Blue palette */
  --ink:       #010D1E;
  --navy:      #04162E;
  --deep:      #08274F;
  --royal:     #0C3D7A;
  --cobalt:    #1459B3;
  --azure:     #1E72D4;
  --cerulean:  #3B9AE8;
  --sky:       #75C0F5;
  --pale:      #BAE0FF;
  --frost:     #E3F2FF;
  --surface:   #F2F7FF;
  --white:     #FFFFFF;

  /* Warm Gold */
  --gold:      #BF9B30;
  --gold-lt:   #E8C558;
  --gold-pale: #FFF3C4;

  /* Text */
  --tx-dark:   #030E1E;
  --tx-body:   #162740;
  --tx-mid:    #385270;
  --tx-soft:   #6880A0;

  /* Glass */
  --gw:  rgba(255,255,255,0.05);
  --gb:  rgba(255,255,255,0.10);
  --gs:  rgba(255,255,255,0.18);

  /* Brand header controls (overridden from Customizer → Header & Top Menu → Brand Colors) */
  --itsi-topbar-bg:        var(--ink);
  --itsi-navbar-bg-color:  rgba(2,12,28,0.88);
  --itsi-pmb-from:         var(--cobalt);
  --itsi-pmb-to:           var(--azure);

  --ease: cubic-bezier(0.22, 1, 0.36, 1);
  --max: 1360px;
  --r:   16px;
}

*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; }
body {
  font-family: 'Plus Jakarta Sans', sans-serif;
  background: var(--white);
  color: var(--tx-body);
  overflow-x: hidden;
  line-height: 1.6;
}
a { text-decoration:none; color:inherit; }
img { display:block; max-width:100%; }
button { font-family:inherit; cursor:pointer; border:none; background:none; }

/* ─── LAYOUT ─── */
.container  { max-width:var(--max); margin:0 auto; padding:0 clamp(1.2rem,4vw,2.8rem); }
.sec-py     { padding: clamp(4.5rem,8vw,7.5rem) 0; }
.sec-py-sm  { padding: clamp(3rem,5vw,5rem) 0; }

/* ─── TYPOGRAPHY ─── */
.h-display { font-family:'Cormorant Garamond',serif; font-weight:700; line-height:1.1; }
.h-display em { font-style:italic; }

.tag-pill {
  display:inline-flex; align-items:center; gap:.45rem;
  font-size:.7rem; font-weight:700; letter-spacing:.13em; text-transform:uppercase;
  padding:.35rem .95rem; border-radius:30px;
  background:var(--frost); color:var(--royal);
}
.tag-pill.dark { background:var(--gw); color:var(--sky); border:1px solid var(--gb); }
.tag-pill::before {
  content:''; width:5px; height:5px; border-radius:50%;
  background:currentColor; flex-shrink:0;
  animation:blink 2.4s ease-in-out infinite;
}
@keyframes blink { 0%,100%{opacity:1} 50%{opacity:.2} }

.sec-label { font-size:.72rem; font-weight:700; letter-spacing:.14em; text-transform:uppercase; color:var(--cobalt); }
.sec-title { font-family:'Cormorant Garamond',serif; font-size:clamp(2rem,3.2vw,3.2rem); font-weight:700; color:var(--tx-dark); line-height:1.15; }
.sec-title-light { color:var(--white); }
.sec-title em { font-style:italic; color:var(--azure); }
.sec-title-light em { color:var(--gold-lt); }
.sec-body { font-size:.97rem; color:var(--tx-mid); line-height:1.8; max-width:560px; }
.sec-body.light { color:rgba(255,255,255,.58); }

/* ─── BUTTONS ─── */
.btn {
  display:inline-flex; align-items:center; gap:.55rem;
  padding:.8rem 1.75rem; border-radius:12px;
  font-size:.87rem; font-weight:600;
  transition:all .28s var(--ease);
}
.btn-primary {
  background:linear-gradient(135deg,var(--azure),var(--royal));
  color:#fff;
  box-shadow:0 8px 28px rgba(30,114,212,.35), inset 0 1px 0 rgba(255,255,255,.18);
}
.btn-primary:hover { transform:translateY(-2px); box-shadow:0 14px 42px rgba(30,114,212,.52); }
.btn-outline { border:1.5px solid var(--pale); color:var(--royal); background:transparent; }
.btn-outline:hover { background:var(--frost); border-color:var(--azure); }
.btn-glass {
  border:1.5px solid var(--gb);
  color:rgba(255,255,255,.85);
  background:var(--gw);
  backdrop-filter:blur(12px);
}
.btn-glass:hover { background:var(--gb); border-color:var(--gs); color:#fff; }
.btn-sm { padding:.52rem 1.2rem; font-size:.8rem; border-radius:9px; }

/* ─── REVEAL ─── */
.rv { opacity:0; transform:translateY(30px); transition:opacity .7s var(--ease), transform .7s var(--ease); }
.rv.from-left  { transform:translateX(-30px); }
.rv.from-right { transform:translateX(30px); }
.rv.scale-in   { transform:scale(.93); }
.rv.on         { opacity:1; transform:none; }
.d1{transition-delay:.08s}.d2{transition-delay:.16s}.d3{transition-delay:.24s}
.d4{transition-delay:.32s}.d5{transition-delay:.40s}.d6{transition-delay:.48s}

/* ═══════════════════════════
   TOP BAR
═══════════════════════════ */
#topbar {
  background:var(--itsi-topbar-bg);
  padding:.42rem clamp(1.2rem,4vw,2.8rem);
  border-bottom:1px solid rgba(255,255,255,.05);
}
.tb-wrap { max-width:var(--max); margin:0 auto; display:flex; align-items:center; justify-content:space-between; gap:1rem; flex-wrap:wrap; }
.tb-left, .tb-right { display:flex; align-items:center; gap:1.2rem; }
.tb-left a, .tb-right a { color:rgba(255,255,255,.45); font-size:.72rem; font-weight:500; transition:color .2s; display:flex; align-items:center; gap:.35rem; }
.tb-left a:hover, .tb-right a:hover { color:#fff; }
.tb-pmb { padding:.28rem .85rem; border-radius:6px; background:linear-gradient(90deg,var(--itsi-pmb-from),var(--itsi-pmb-to)); color:#fff !important; font-weight:700 !important; }

/* ═══════════════════════════
   NAVBAR
═══════════════════════════ */
#navbar {
  position:sticky; top:0; z-index:900;
  background:var(--itsi-navbar-bg-color);
  backdrop-filter:blur(26px) saturate(180%);
  -webkit-backdrop-filter:blur(26px) saturate(180%);
  border-bottom:1px solid rgba(255,255,255,.07);
  transition:background .3s, box-shadow .3s;
}
#navbar.scrolled { background:var(--itsi-navbar-bg-color); box-shadow:0 4px 44px rgba(0,0,0,.55); }
.nav-wrap { max-width:var(--max); margin:0 auto; padding:0 clamp(1.2rem,4vw,2.8rem); display:flex; align-items:center; height:70px; gap:1.5rem; }

.nav-brand { display:flex; align-items:center; gap:12px; flex-shrink:0; }
.nav-brand img { height:42px; width:auto; }
.nb-text { display:flex; flex-direction:column; line-height:1; }
.nb-text .nb-short { font-size:.6rem; font-weight:800; letter-spacing:.16em; text-transform:uppercase; color:var(--cerulean); }
.nb-text .nb-full  { font-size:.82rem; font-weight:700; color:#fff; line-height:1.25; max-width:185px; }

.nav-links { display:flex; align-items:center; gap:.1rem; margin-left:auto; list-style:none; padding:0; }
.nli { position:relative; list-style:none; padding:0; margin:0; }
.nav-links > li { list-style:none; padding:0; margin:0; }
.nl-a {
  display:flex; align-items:center; gap:.3rem;
  padding:.5rem .85rem; border-radius:9px;
  color:rgba(255,255,255,.68); font-size:.83rem; font-weight:500;
  transition:all .2s; white-space:nowrap;
}
.nl-a:hover, .nl-a.active { color:#fff; background:var(--gw); }
.nl-a svg { width:11px; height:11px; opacity:.55; transition:transform .25s; }
.nli:hover .nl-a svg { transform:rotate(180deg); }

.dd {
  position:absolute; top:calc(100% + 8px); left:50%;
  transform:translateX(-50%) translateY(-8px);
  background:rgba(2,14,34,.97); backdrop-filter:blur(24px);
  border:1px solid rgba(255,255,255,.1); border-radius:16px;
  padding:.7rem; min-width:250px;
  opacity:0; visibility:hidden; pointer-events:none;
  transition:all .25s var(--ease);
  box-shadow:0 28px 72px rgba(0,0,0,.65);
  list-style:none; /* wp_nav_menu outputs <ul class="dd">; reset bullets. */
}
.dd > li { list-style:none; padding:0; margin:0; }
.nli:hover .dd { opacity:1; visibility:visible; pointer-events:auto; transform:translateX(-50%) translateY(0); }
.dd-group + .dd-group { border-top:1px solid rgba(255,255,255,.07); margin-top:.35rem; padding-top:.35rem; }
.dd-label { padding:.3rem .85rem; font-size:.66rem; font-weight:800; letter-spacing:.13em; text-transform:uppercase; color:var(--cerulean); }
.dd-a {
  display:flex; align-items:center; gap:.75rem;
  padding:.6rem .85rem; border-radius:10px;
  color:rgba(255,255,255,.68); font-size:.82rem; font-weight:500;
  transition:all .2s;
}
.dd-a:hover { background:var(--gw); color:#fff; }
.dd-ic { width:28px; height:28px; border-radius:7px; background:var(--gw); display:flex; align-items:center; justify-content:center; font-size:.9rem; flex-shrink:0; }

.nav-actions { display:flex; align-items:center; gap:.4rem; flex-shrink:0; }
.nav-btn {
  width:36px; height:36px; border-radius:9px;
  background:var(--gw); border:1px solid rgba(255,255,255,.09);
  color:rgba(255,255,255,.65); display:flex; align-items:center; justify-content:center;
  transition:all .2s;
}
.nav-btn:hover { background:var(--gb); color:#fff; }
.hamburger { display:none; flex-direction:column; gap:5px; padding:5px; }
.hamburger span { width:22px; height:2px; background:#fff; border-radius:2px; display:block; transition:all .3s; }
.hamburger.open span:nth-child(1) { transform:translateY(7px) rotate(45deg); }
.hamburger.open span:nth-child(2) { opacity:0; }
.hamburger.open span:nth-child(3) { transform:translateY(-7px) rotate(-45deg); }

.mob-nav {
  position:fixed; top:70px; left:0; right:0; bottom:0; z-index:899;
  background:rgba(1,10,22,.98); backdrop-filter:blur(20px);
  overflow-y:auto; padding:1.5rem;
  transform:translateX(100%); transition:transform .35s var(--ease);
}
.mob-nav.open { transform:translateX(0); }
.mob-a { display:flex; align-items:center; gap:.75rem; padding:.85rem 1rem; border-radius:11px; color:rgba(255,255,255,.75); font-size:.9rem; font-weight:500; border-bottom:1px solid rgba(255,255,255,.05); transition:all .2s; }
.mob-a:hover { background:var(--gw); color:#fff; }
.mob-sec-ttl { padding:.55rem 1rem .25rem; font-size:.67rem; font-weight:800; letter-spacing:.13em; text-transform:uppercase; color:var(--cerulean); }

.search-ovl {
  position:fixed; inset:0; z-index:9999;
  background:rgba(1,10,22,.94); backdrop-filter:blur(22px);
  display:flex; align-items:flex-start; justify-content:center; padding-top:18vh;
  opacity:0; pointer-events:none; transition:opacity .25s;
}
.search-ovl.open { opacity:1; pointer-events:auto; }
.search-box { width:min(660px,92vw); }
.search-hint-ttl { font-size:.73rem; font-weight:700; letter-spacing:.13em; text-transform:uppercase; color:rgba(255,255,255,.35); margin-bottom:.9rem; }
.search-field { position:relative; }
.search-field-icon { position:absolute; left:1.15rem; top:50%; transform:translateY(-50%); color:rgba(255,255,255,.35); pointer-events:none; }
.search-inp {
  width:100%; padding:1.15rem 3.2rem;
  background:rgba(255,255,255,.07); border:1.5px solid rgba(255,255,255,.14);
  border-radius:16px; color:#fff; font-family:inherit; font-size:1.08rem; outline:none;
  transition:border-color .2s;
}
.search-inp::placeholder { color:rgba(255,255,255,.28); }
.search-inp:focus { border-color:var(--azure); }
.search-close-btn { position:absolute; right:1rem; top:50%; transform:translateY(-50%); background:none; border:none; color:rgba(255,255,255,.4); font-size:1.1rem; cursor:pointer; transition:color .2s; }
.search-close-btn:hover { color:#fff; }
.search-note { font-size:.76rem; color:rgba(255,255,255,.25); margin-top:.75rem; }

/* ═══════════════════════════
   HERO
═══════════════════════════ */
#hero {
  position:relative; overflow:hidden;
  background:var(--ink);
  min-height:100svh; display:flex; align-items:center;
}
.hero-bg { position:absolute; inset:0; }
.hero-mesh {
  position:absolute; inset:-10%;
  background:
    radial-gradient(ellipse 60% 55% at 65% 25%, rgba(12,61,122,.6) 0%, transparent 65%),
    radial-gradient(ellipse 45% 40% at 12% 70%, rgba(8,39,79,.8) 0%, transparent 60%),
    radial-gradient(ellipse 40% 35% at 90% 80%, rgba(4,22,46,.9) 0%, transparent 55%);
  animation:meshBreathe 14s ease-in-out infinite alternate;
}
@keyframes meshBreathe { 0%{opacity:.9;transform:scale(1)}100%{opacity:1;transform:scale(1.05)} }
.hero-dots {
  position:absolute; inset:0; opacity:.028;
  background-image:radial-gradient(circle, rgba(117,192,245,1) 1.2px, transparent 1.2px);
  background-size:48px 48px;
}
.hero-lines { position:absolute; inset:0; opacity:.05; pointer-events:none; }
.hero-lines svg { width:100%; height:100%; }
.blob { position:absolute; border-radius:50%; filter:blur(90px); pointer-events:none; }
.blob-1 { width:640px; height:640px; background:radial-gradient(circle,rgba(20,89,179,.22),transparent 70%); top:-20%; right:-8%; animation:floatA 15s ease-in-out infinite; }
.blob-2 { width:420px; height:420px; background:radial-gradient(circle,rgba(8,39,79,.3),transparent 70%); bottom:-5%; left:-6%; animation:floatB 12s ease-in-out infinite; }
.blob-3 { width:260px; height:260px; background:radial-gradient(circle,rgba(191,155,48,.1),transparent 70%); top:42%; right:26%; animation:floatA 9s ease-in-out 3.5s infinite; }
@keyframes floatA { 0%,100%{transform:translateY(0) rotate(0)}50%{transform:translateY(-38px) rotate(8deg)} }
@keyframes floatB { 0%,100%{transform:translateY(0)}50%{transform:translateY(30px)} }

.hero-ring {
  position:absolute; right:-180px; top:50%; transform:translateY(-50%);
  width:700px; height:700px; border-radius:50%;
  border:1px solid rgba(59,154,232,.1);
}
.hero-ring::before { content:''; position:absolute; inset:60px; border-radius:50%; border:1px solid rgba(59,154,232,.08); }
.hero-ring::after  { content:''; position:absolute; inset:130px; border-radius:50%; border:1px solid rgba(59,154,232,.06); }

.hero-inner { position:relative; z-index:2; width:100%; }
.hero-grid { display:grid; grid-template-columns:1fr 1fr; gap:clamp(2.5rem,5vw,5rem); align-items:center; padding-block:clamp(7rem,14vh,10rem) clamp(5rem,8vh,7rem); }

.hero-eyebrow { animation:fadeUp .7s var(--ease) both; }
.hero-h1 {
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(2.6rem,4.8vw,5rem);
  font-weight:700; color:#fff; line-height:1.08;
  margin:.95rem 0 1.35rem;
  animation:fadeUp .7s .14s var(--ease) both;
}
.hero-h1 em { font-style:italic; color:var(--gold-lt); }
.hero-p { font-size:1.02rem; line-height:1.84; color:rgba(255,255,255,.58); max-width:490px; animation:fadeUp .7s .28s var(--ease) both; }
.hero-cta { display:flex; gap:1rem; flex-wrap:wrap; margin-top:2.2rem; animation:fadeUp .7s .42s var(--ease) both; }

.hero-card-wrap { animation:fadeUp .7s .18s var(--ease) both; }
.hero-card {
  background:linear-gradient(155deg, rgba(10,40,90,.72) 0%, rgba(4,22,46,.85) 100%);
  border:1px solid rgba(255,255,255,.12); border-radius:22px;
  padding:2rem; backdrop-filter:blur(18px);
}
.hc-stats { display:grid; grid-template-columns:1fr 1fr; gap:1rem; margin-bottom:1.6rem; }
.hc-stat { background:rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.08); border-radius:14px; padding:1.3rem 1.1rem; }
.hc-num { font-family:'Cormorant Garamond',serif; font-size:2.2rem; color:var(--cerulean); line-height:1; font-weight:700; }
.hc-lbl { font-size:.73rem; color:rgba(255,255,255,.45); margin-top:.3rem; }
.hc-sep { height:1px; background:rgba(255,255,255,.07); margin-bottom:1.4rem; }
.hc-ann-ttl { font-size:.68rem; font-weight:800; letter-spacing:.13em; text-transform:uppercase; color:var(--gold-lt); margin-bottom:.85rem; }
.hc-ann-item { display:flex; align-items:flex-start; gap:.7rem; padding:.55rem .65rem; border-radius:10px; cursor:pointer; transition:background .2s; text-decoration:none; }
.hc-ann-item:hover { background:rgba(255,255,255,.06); }
.hc-ann-dot { width:7px; height:7px; border-radius:50%; background:var(--cerulean); flex-shrink:0; margin-top:5px; }
.hc-ann-date { font-size:.67rem; font-weight:700; color:var(--sky); min-width:48px; flex-shrink:0; }
.hc-ann-text { font-size:.8rem; color:rgba(255,255,255,.7); line-height:1.45; }

@keyframes fadeUp { from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)} }

.scroll-ind { position:absolute; bottom:2rem; left:50%; transform:translateX(-50%); display:flex; flex-direction:column; align-items:center; gap:.45rem; color:rgba(255,255,255,.25); font-size:.67rem; letter-spacing:.15em; text-transform:uppercase; animation:scrollBounce 2.4s ease-in-out infinite; }
@keyframes scrollBounce { 0%,100%{transform:translateX(-50%) translateY(0)}50%{transform:translateX(-50%) translateY(9px)} }

/* ═══════════════════════════
   SAMBUTAN REKTOR
═══════════════════════════ */
#sambutan { background:var(--surface); }
.sam-grid { display:grid; grid-template-columns:360px 1fr; gap:clamp(2.5rem,5vw,5.5rem); align-items:center; }
.sam-card {
  background:linear-gradient(155deg, var(--royal) 0%, var(--deep) 60%, var(--cobalt) 100%);
  border-radius:24px; padding:2.4rem 2rem; text-align:center;
  position:relative; overflow:hidden;
  box-shadow:0 28px 70px rgba(4,22,46,.45);
}
.sam-card::before { content:''; position:absolute; width:280px;height:280px;border-radius:50%; background:rgba(255,255,255,.05); top:-80px; right:-80px; }
.sam-card::after  { content:''; position:absolute; width:200px;height:200px;border-radius:50%; background:rgba(255,255,255,.04); bottom:-60px; left:-50px; }
.sam-avatar { width:115px; height:115px; border-radius:50%; margin:0 auto 1.2rem; background:rgba(255,255,255,.12); border:3px solid rgba(255,255,255,.22); display:flex; align-items:center; justify-content:center; font-size:2.8rem; position:relative; z-index:1; }
.sam-name { font-family:'Cormorant Garamond',serif; font-size:1.15rem; font-weight:700; color:#fff; margin-bottom:.3rem; position:relative; z-index:1; }
.sam-pos { font-size:.78rem; color:rgba(255,255,255,.55); position:relative; z-index:1; margin-bottom:1.2rem; }
.sam-badge { display:inline-block; background:rgba(255,255,255,.1); border:1px solid rgba(255,255,255,.2); color:rgba(255,255,255,.82); padding:.33rem .9rem; border-radius:8px; font-size:.73rem; font-weight:700; position:relative; z-index:1; }
.sam-dots { display:flex; align-items:center; justify-content:center; gap:.5rem; margin-top:1.3rem; position:relative; z-index:1; }
.sam-dots span { font-size:.7rem; color:rgba(255,255,255,.38); }
.sam-dots i { width:4px; height:4px; border-radius:50%; background:var(--gold-lt); display:block; }

.sam-blockquote { font-family:'Cormorant Garamond',serif; font-style:italic; font-size:clamp(1.2rem,1.8vw,1.55rem); line-height:1.68; color:var(--tx-dark); margin:1.2rem 0 1.7rem; padding-left:1.4rem; border-left:3px solid var(--azure); }
.sam-body { font-size:.95rem; color:var(--tx-mid); line-height:1.84; }
.sam-body p+p { margin-top:.9rem; }
.sam-more { display:inline-flex; align-items:center; gap:.45rem; color:var(--cobalt); font-weight:700; font-size:.88rem; margin-top:1.6rem; border-bottom:2px solid var(--frost); transition:all .2s; }
.sam-more:hover { border-color:var(--cobalt); }
.sam-more:hover svg { transform:translateX(4px); }

/* ═══════════════════════════
   PROGRAM STUDI
═══════════════════════════ */
#prodi { background:#fff; }
.prodi-tab-wrap { display:flex; gap:.45rem; padding:.3rem; background:var(--surface); border:1px solid var(--frost); border-radius:13px; width:fit-content; }
.ptab { padding:.55rem 1.35rem; border-radius:10px; font-size:.82rem; font-weight:700; color:var(--tx-mid); background:transparent; cursor:pointer; transition:all .25s; white-space:nowrap; }
.ptab.on { background:#fff; color:var(--royal); box-shadow:0 2px 14px rgba(0,0,0,.09); }
.ptab:hover:not(.on) { color:var(--azure); }
.prodi-panel { display:none; }
.prodi-panel.on { display:block; }
.fac-banner { display:flex; align-items:center; gap:1.3rem; background:linear-gradient(135deg,var(--navy),var(--deep)); border-radius:18px; padding:1.7rem 2rem; margin-bottom:1.7rem; border:1px solid rgba(255,255,255,.05); }
.fac-ic { font-size:2.2rem; }
.fac-text h3 { font-family:'Cormorant Garamond',serif; font-size:1.25rem; font-weight:700; color:#fff; }
.fac-text p  { font-size:.83rem; color:rgba(255,255,255,.52); margin-top:.2rem; }
.prodi-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:1.25rem; }
.prodi-grid-2 { grid-template-columns:repeat(2,1fr); max-width:660px; }
.pc {
  background:var(--surface); border:1px solid #dbe9ff; border-radius:18px;
  padding:1.7rem; position:relative; overflow:hidden;
  transition:all .32s var(--ease);
  display:flex; flex-direction:column;
}
.pc::after {
  content:''; position:absolute; top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,var(--royal),var(--cerulean));
  transform:scaleX(0); transform-origin:left;
  transition:transform .35s var(--ease);
}
.pc:hover { border-color:#b0ccff; box-shadow:0 16px 52px rgba(12,61,122,.1); transform:translateY(-5px); }
.pc:hover::after { transform:scaleX(1); }
.pc-icon { font-size:1.9rem; margin-bottom:1rem; }
.pc-deg { display:inline-block; font-size:.67rem; font-weight:800; letter-spacing:.1em; text-transform:uppercase; background:var(--frost); color:var(--royal); padding:.2rem .6rem; border-radius:6px; margin-bottom:.7rem; align-self:flex-start; }
.pc-name { font-size:.95rem; font-weight:700; color:var(--tx-dark); line-height:1.4; margin-bottom:.6rem; }
.pc-desc { font-size:.81rem; color:var(--tx-soft); line-height:1.65; flex:1; margin-bottom:1.1rem; }
.pc-link { display:inline-flex; align-items:center; gap:.35rem; font-size:.79rem; font-weight:700; color:var(--cobalt); transition:gap .2s; }
.pc-link:hover { gap:.55rem; }

/* ═══════════════════════════
   INFOGRAFIS
═══════════════════════════ */
#infografis { background:linear-gradient(160deg,var(--ink) 0%,var(--navy) 50%,var(--ink) 100%); position:relative; overflow:hidden; }
.info-glow { position:absolute; inset:0; background:radial-gradient(ellipse 80% 55% at 50% 50%,rgba(20,89,179,.14) 0%,transparent 70%); pointer-events:none; }
.info-grid { display:grid; grid-template-columns:repeat(5,1fr); gap:1.4rem; }
.info-card { background:var(--gw); border:1px solid var(--gb); border-radius:20px; padding:2rem 1.5rem; text-align:center; backdrop-filter:blur(12px); transition:all .3s var(--ease); }
.info-card:hover { background:var(--gb); transform:translateY(-6px); }
.info-em { font-size:2.2rem; margin-bottom:.85rem; display:block; }
.info-num { font-family:'Cormorant Garamond',serif; font-size:2.4rem; font-weight:700; color:var(--cerulean); line-height:1; }
.info-lbl { font-size:.77rem; color:rgba(255,255,255,.52); margin-top:.38rem; line-height:1.45; }
.info-row2 { display:grid; grid-template-columns:repeat(5,1fr); gap:1.4rem; margin-top:1.4rem; }

/* ═══════════════════════════
   BERITA & KEGIATAN
═══════════════════════════ */
#berita { background:var(--surface); }
.news-chips { display:flex; gap:.45rem; flex-wrap:wrap; }
.chip { padding:.4rem 1rem; border-radius:30px; font-size:.77rem; font-weight:700; background:#fff; border:1.5px solid #dbe9ff; color:var(--tx-mid); cursor:pointer; transition:all .22s; }
.chip.on { background:var(--cobalt); border-color:var(--cobalt); color:#fff; box-shadow:0 4px 16px rgba(20,89,179,.32); }
.chip:hover:not(.on) { border-color:var(--azure); color:var(--cobalt); }

.news-layout { display:grid; grid-template-columns:1fr 380px; gap:2rem; margin-top:2rem; }

.nfeat { background:#fff; border:1px solid #dbe9ff; border-radius:22px; overflow:hidden; transition:all .3s var(--ease); display:flex; flex-direction:column; }
.nfeat:hover { box-shadow:0 20px 64px rgba(12,61,122,.14); transform:translateY(-4px); }
.nf-img-link { display:block; line-height:0; text-decoration:none; color:inherit; }
.nf-img-link:focus-visible { outline:2px solid var(--cobalt); outline-offset:2px; }
.nf-title-link { color:var(--tx-dark); text-decoration:none; }
.nf-title-link:hover { color:var(--cobalt); }
.nf-title-link:focus-visible { outline:2px solid var(--cobalt); outline-offset:2px; border-radius:3px; }
.nf-img { height:265px; position:relative; overflow:hidden; display:flex; align-items:center; justify-content:center; font-size:5rem; background:linear-gradient(135deg,#04162E,#1459B3); }
.nf-img::after { content:''; position:absolute;inset:0; background:linear-gradient(to top,rgba(2,12,28,.55) 0%,transparent 55%); }
.nf-cat-badge { position:absolute; top:1.1rem; left:1.1rem; z-index:1; padding:.26rem .72rem; border-radius:7px; font-size:.68rem; font-weight:800; text-transform:uppercase; letter-spacing:.07em; background:var(--cobalt); color:#fff; }
.nf-body { padding:1.75rem; flex:1; }
.nf-date-row { display:flex; align-items:center; gap:.9rem; font-size:.73rem; color:var(--tx-soft); margin-bottom:.75rem; }
.nf-title { font-family:'Cormorant Garamond',serif; font-size:1.25rem; font-weight:700; color:var(--tx-dark); line-height:1.42; margin-bottom:.8rem; }
.nf-excerpt { font-size:.84rem; color:var(--tx-mid); line-height:1.72; margin-bottom:1.2rem; }
.nf-meta { display:flex; align-items:center; gap:1.2rem; padding-top:1rem; border-top:1px solid var(--frost); flex-wrap:wrap; }
.nf-meta-i { display:flex; align-items:center; gap:.35rem; font-size:.73rem; color:var(--tx-soft); }
.nf-share { display:flex; align-items:center; gap:.45rem; margin-top:1rem; padding-top:1rem; border-top:1px solid var(--frost); }
.nf-share-lbl { font-size:.72rem; font-weight:600; text-transform:uppercase; letter-spacing:.06em; color:var(--tx-soft); margin-right:auto; }
.share-btn { width:32px;height:32px;border-radius:9px;background:var(--frost);border:none;color:var(--tx-dark);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:all .2s var(--ease); text-decoration:none; }
.share-btn:hover { background:var(--cobalt); color:#fff; transform:translateY(-2px); box-shadow:0 6px 16px rgba(12,61,122,.22); }
.share-ico { width:15px; height:15px; flex-shrink:0; }

.nside { display:flex; flex-direction:column; gap:.9rem; }
.ns-card { display:flex; gap:.95rem; align-items:flex-start; background:#fff; border:1px solid #dbe9ff; border-radius:15px; padding:1.05rem; cursor:pointer; transition:all .25s var(--ease); }
.ns-card:hover { border-color:#99bcee; box-shadow:0 8px 28px rgba(12,61,122,.09); transform:translateX(3px); }
.ns-img { width:70px;height:70px;border-radius:11px;flex-shrink:0;background:linear-gradient(135deg,var(--royal),var(--azure));display:flex;align-items:center;justify-content:center;font-size:1.5rem; }
.ns-body { flex:1; min-width:0; }
.ns-cat { font-size:.66rem; font-weight:800; text-transform:uppercase; letter-spacing:.08em; color:var(--cobalt); margin-bottom:.28rem; }
.ns-title { font-size:.83rem; font-weight:600; color:var(--tx-dark); line-height:1.45; margin-bottom:.35rem; display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden; }
.ns-date { font-size:.71rem; color:var(--tx-soft); }

/* ═══════════════════════════
   PENGUMUMAN
═══════════════════════════ */
#pengumuman { background:#fff; }
.peng-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:1.4rem; }
.peng { background:var(--surface); border:1px solid #dbe9ff; border-radius:20px; padding:1.6rem; cursor:pointer; transition:all .3s var(--ease); display:flex; flex-direction:column; }
.peng:hover { border-color:#99bcee; box-shadow:0 12px 42px rgba(12,61,122,.1); transform:translateY(-4px); }
.peng-date-tag { display:inline-flex; align-items:center; gap:.4rem; background:var(--frost); color:var(--royal); padding:.28rem .75rem; border-radius:8px; font-size:.71rem; font-weight:800; margin-bottom:.95rem; align-self:flex-start; }
.peng-title { font-size:.93rem; font-weight:700; color:var(--tx-dark); line-height:1.5; margin-bottom:.65rem; flex:1; }
.peng-body { font-size:.81rem; color:var(--tx-mid); line-height:1.65; margin-bottom:1rem; }
.peng-foot { display:flex; align-items:center; justify-content:space-between; padding-top:.85rem; border-top:1px solid var(--frost); }
.peng-author { display:flex; align-items:center; gap:.4rem; font-size:.72rem; color:var(--tx-soft); }
.peng-actions { display:flex; gap:.35rem; }
.peng-btn { width:28px;height:28px;border-radius:7px;background:var(--frost);border:none;font-size:.78rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s; }
.peng-btn:hover { background:var(--azure); transform:scale(1.1); }

/* ═══════════════════════════
   ARTIKEL
═══════════════════════════ */
#artikel { background:var(--surface); }
.art-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:1.5rem; }
.art-card { background:#fff; border:1px solid #dbe9ff; border-radius:22px; overflow:hidden; cursor:pointer; transition:all .32s var(--ease); display:flex; flex-direction:column; }
.art-card:hover { box-shadow:0 20px 64px rgba(12,61,122,.13); transform:translateY(-6px); border-color:#99bcee; }
.art-img { height:168px; position:relative; display:flex; align-items:center; justify-content:center; font-size:3rem; overflow:hidden; background:linear-gradient(135deg,#04162E,#1459B3); }
.art-img-cat { position:absolute;top:1rem;left:1rem;z-index:1; }
.art-body { padding:1.5rem; flex:1; display:flex; flex-direction:column; }
.art-title { font-size:.92rem; font-weight:700; color:var(--tx-dark); line-height:1.5; margin-bottom:.65rem; flex:1; }
.art-excerpt { font-size:.81rem; color:var(--tx-mid); line-height:1.65; margin-bottom:.95rem; display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden; }
.art-meta { display:flex; align-items:center; gap:.85rem; padding-top:.85rem; border-top:1px solid var(--frost); flex-wrap:wrap; }
.art-meta-i { display:flex; align-items:center; gap:.3rem; font-size:.71rem; color:var(--tx-soft); }

/* ═══════════════════════════
   MITRA SLIDER
═══════════════════════════ */
#mitra { background:#fff; overflow:hidden; }
.mitra-track-wrap { position:relative; overflow:hidden; }
.mitra-fade { position:absolute;top:0;bottom:0;width:140px;z-index:2;pointer-events:none; }
.mitra-fade-l { left:0; background:linear-gradient(to right,#fff,transparent); }
.mitra-fade-r { right:0; background:linear-gradient(to left,#fff,transparent); }
.mitra-track { display:flex; gap:1.3rem; width:max-content; animation:mitraRoll 32s linear infinite; }
.mitra-track:hover { animation-play-state:paused; }
.mitra-chip { display:flex; align-items:center; gap:.75rem; padding:.9rem 1.6rem; border-radius:14px; background:var(--surface); border:1.5px solid #dbe9ff; white-space:nowrap; cursor:default; transition:all .25s; }
.mitra-chip:hover { border-color:#99bcee; box-shadow:0 6px 22px rgba(12,61,122,.1); }
.mitra-logo { font-size:1.7rem; flex-shrink:0; display:flex; align-items:center; justify-content:center; }
.mitra-logo img { width:36px; height:36px; object-fit:contain; display:block; }
.mitra-logo svg { width:36px; height:36px; display:block; }
.mitra-name { font-size:.8rem; font-weight:700; color:var(--tx-mid); }
@keyframes mitraRoll { 0%{transform:translateX(0)}100%{transform:translateX(-50%)} }

/* ═══════════════════════════
   INFORMASI PUBLIK
═══════════════════════════ */
#infopub { background:linear-gradient(155deg,var(--navy) 0%,var(--deep) 60%,var(--navy) 100%); position:relative; overflow:hidden; }
.ip-glow { position:absolute;inset:0;background:radial-gradient(ellipse 70% 55% at 50% 50%,rgba(20,89,179,.12) 0%,transparent 70%);pointer-events:none; }
.ip-grid { display:grid; grid-template-columns:1fr 1fr; gap:clamp(2.5rem,5vw,5.5rem); align-items:start; position:relative; z-index:1; }
.ip-cats { display:flex; flex-direction:column; gap:.6rem; margin-top:1.7rem; }
.ip-cat-btn { display:flex; align-items:center; gap:.85rem; padding:.95rem 1.25rem; border-radius:13px; background:var(--gw); border:1px solid var(--gb); color:rgba(255,255,255,.78); font-size:.87rem; font-weight:500; cursor:pointer; transition:all .22s; text-align:left; text-decoration:none; }
.ip-cat-btn:hover { background:var(--gs); color:#fff; transform:translateX(4px); }
.ip-cat-ic { font-size:1.2rem; }
.ip-cat-arr { margin-left:auto; opacity:.4; }
.ip-right { display:flex; flex-direction:column; gap:1rem; }
.ip-card { background:var(--gw); border:1px solid var(--gb); border-radius:15px; padding:1.35rem; backdrop-filter:blur(10px); cursor:pointer; transition:all .25s var(--ease); }
.ip-card:hover { background:var(--gb); transform:translateY(-3px); }
.ip-tag { font-size:.66rem; font-weight:800; letter-spacing:.1em; text-transform:uppercase; color:var(--sky); margin-bottom:.45rem; }
.ip-title { font-size:.89rem; font-weight:600; color:#fff; line-height:1.48; margin-bottom:.72rem; }
.ip-meta { display:flex; align-items:center; gap:.9rem; flex-wrap:wrap; }
.ip-meta span { font-size:.71rem; color:rgba(255,255,255,.42); display:flex; align-items:center; gap:.3rem; }
.ip-acts { margin-left:auto; display:flex; gap:.38rem; }
.ip-act { width:27px;height:27px;border-radius:7px;background:var(--gw);border:1px solid var(--gb);color:rgba(255,255,255,.65);font-size:.77rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s; }
.ip-act:hover { background:var(--gs); color:#fff; }

/* ═══════════════════════════
   FOOTER
═══════════════════════════ */
footer { background:var(--ink); border-top:1px solid rgba(255,255,255,.05); }
.footer-top { padding:clamp(3rem,6vw,5.5rem) 0 clamp(2.5rem,5vw,4rem); }
.footer-grid { display:grid; grid-template-columns:2fr 1fr 1fr 1fr; gap:3rem; }
.f-logo { display:flex; align-items:center; gap:11px; margin-bottom:1.2rem; }
.f-logo img { height:40px; }
.f-logo-txt .flt-s { display:block; font-size:.6rem; font-weight:800; letter-spacing:.15em; text-transform:uppercase; color:var(--cerulean); }
.f-logo-txt .flt-l { display:block; font-size:.82rem; font-weight:700; color:#fff; line-height:1.28; }
.f-desc { font-size:.84rem; color:rgba(255,255,255,.4); line-height:1.78; margin-bottom:1.4rem; }
.f-socials { display:flex; gap:.5rem; }
.f-soc { width:34px;height:34px;border-radius:9px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);color:rgba(255,255,255,.5);font-size:.95rem;display:flex; align-items:center;justify-content:center;transition:all .22s; }
.f-soc:hover { background:var(--cobalt); border-color:transparent; color:#fff; }
.f-col-ttl { font-size:.7rem; font-weight:800; letter-spacing:.14em; text-transform:uppercase; color:var(--cerulean); margin-bottom:1.1rem; }
.f-col ul { display:flex; flex-direction:column; gap:.52rem; list-style:none; }
.f-col a { font-size:.84rem; color:rgba(255,255,255,.42); transition:color .2s; display:flex; align-items:center; gap:.38rem; }
.f-col a:hover { color:rgba(255,255,255,.85); }
.footer-bottom { border-top:1px solid rgba(255,255,255,.06); padding:1.5rem 0; display:flex; align-items:center; justify-content:space-between; gap:1rem; flex-wrap:wrap; }
.f-copy { font-size:.78rem; color:rgba(255,255,255,.28); }
.f-links { display:flex; gap:1.4rem; flex-wrap:wrap; }
.f-links a { font-size:.78rem; color:rgba(255,255,255,.28); transition:color .2s; }
.f-links a:hover { color:rgba(255,255,255,.65); }

#scrollTop { position:fixed;bottom:1.8rem;right:1.8rem;z-index:800;width:44px;height:44px;border-radius:12px;background:linear-gradient(135deg,var(--cobalt),var(--royal));border:none;color:#fff;cursor:pointer;font-size:1rem;display:none;align-items:center;justify-content:center;box-shadow:0 6px 22px rgba(20,89,179,.45);transition:all .25s var(--ease); }
#scrollTop.show { display:flex; }
#scrollTop:hover { transform:translateY(-3px); box-shadow:0 10px 32px rgba(20,89,179,.6); }

.accent-bar { height:3px; background:linear-gradient(90deg,var(--royal) 0%,var(--cerulean) 50%,var(--gold) 100%); }

/* ═══════════════════════════
   RESPONSIVE
═══════════════════════════ */
@media(max-width:1200px){
  .info-grid,.info-row2 { grid-template-columns:repeat(3,1fr); }
  .footer-grid { grid-template-columns:1fr 1fr; }
  .prodi-grid { grid-template-columns:repeat(2,1fr); }
}
@media(max-width:1024px){
  .hero-grid { grid-template-columns:1fr; }
  .hc-stats { grid-template-columns:repeat(4,1fr); }
  .sam-grid { grid-template-columns:1fr; }
  .news-layout { grid-template-columns:1fr; }
  .ip-grid { grid-template-columns:1fr; }
}
@media(max-width:900px){
  .peng-grid { grid-template-columns:repeat(2,1fr); }
  .art-grid { grid-template-columns:repeat(2,1fr); }
}
@media(max-width:768px){
  #topbar { display:none; }
  .nav-links,.nav-actions { display:none; }
  .hamburger { display:flex; }
  .info-grid,.info-row2 { grid-template-columns:repeat(2,1fr); }
  .peng-grid { grid-template-columns:1fr; }
  .art-grid { grid-template-columns:1fr; }
  .prodi-grid,.prodi-grid-2 { grid-template-columns:1fr; }
  .footer-grid { grid-template-columns:1fr; }
  .footer-bottom { flex-direction:column; text-align:center; }
  .f-links { justify-content:center; }
  .hero-cta { flex-direction:column; }
  .hero-cta .btn { justify-content:center; }
  .hc-stats { grid-template-columns:repeat(2,1fr); }
}
@media(max-width:480px){
  .info-grid,.info-row2 { grid-template-columns:1fr 1fr; }
}

/* ═══════════════════════════
   WORDPRESS CONTENT INTEGRATION
═══════════════════════════ */
.site-main { min-height: 60vh; }

.entry-content { max-width: 860px; margin: 0 auto; padding: 0 clamp(1.2rem,4vw,2.8rem) 4rem; }
.entry-content h1, .entry-content h2, .entry-content h3 { font-family:'Cormorant Garamond',serif; color:var(--tx-dark); margin: 2rem 0 1rem; line-height: 1.25; }
.entry-content h2 { font-size: clamp(1.6rem, 2.4vw, 2.2rem); }
.entry-content h3 { font-size: clamp(1.2rem, 1.8vw, 1.5rem); }
.entry-content p  { font-size: 1rem; color: var(--tx-body); line-height: 1.85; margin-bottom: 1rem; }
.entry-content a  { color: var(--cobalt); font-weight: 600; border-bottom: 1.5px solid var(--frost); transition: border-color .2s; }
.entry-content a:hover { border-color: var(--cobalt); }
.entry-content ul, .entry-content ol { margin: 1rem 0 1rem 1.5rem; }
.entry-content li { margin-bottom: .4rem; line-height: 1.7; }
.entry-content img { border-radius: 14px; margin: 1.5rem 0; }
.entry-content blockquote { font-family:'Cormorant Garamond',serif; font-style:italic; font-size: 1.3rem; color: var(--tx-dark); border-left: 3px solid var(--azure); padding-left: 1.4rem; margin: 1.5rem 0; }
.entry-content code { background: var(--frost); color: var(--royal); padding: .15rem .4rem; border-radius: 5px; font-size: .9em; }
.entry-content pre { background: var(--navy); color: #fff; padding: 1.25rem; border-radius: 12px; overflow-x: auto; }

.entry-title { font-family:'Cormorant Garamond',serif; font-size: clamp(2rem, 3.5vw, 2.8rem); font-weight: 700; color: var(--tx-dark); line-height: 1.15; padding: clamp(4rem,8vw,7rem) clamp(1.2rem,4vw,2.8rem) 1rem; max-width: 860px; margin: 0 auto; }
.entry-title a { color: var(--tx-dark); border-bottom: 0; }
.entry-meta { color: var(--tx-soft); font-size: .82rem; padding: 0 clamp(1.2rem,4vw,2.8rem) 1.5rem; max-width: 860px; margin: 0 auto; }
.entry-footer { padding: 1.5rem clamp(1.2rem,4vw,2.8rem) 3rem; max-width: 860px; margin: 0 auto; color: var(--tx-soft); font-size: .85rem; }
.page-header { max-width: 860px; margin: 0 auto; padding: clamp(4rem,8vw,7rem) clamp(1.2rem,4vw,2.8rem) 1rem; }
.page-title { font-family:'Cormorant Garamond',serif; font-size: clamp(2rem, 3.5vw, 2.8rem); font-weight: 700; color: var(--tx-dark); }

.wp-post-thumbnail { border-radius: 18px; margin: 1.5rem auto; max-width: 860px; display: block; }

.posts-navigation, .pagination { padding: 2rem clamp(1.2rem,4vw,2.8rem); display: flex; gap: 1rem; justify-content: center; }
.posts-navigation a, .pagination a, .pagination span { padding: .6rem 1.2rem; border-radius: 9px; background: var(--surface); border: 1px solid #dbe9ff; color: var(--royal); font-weight: 600; font-size: .85rem; }
.posts-navigation a:hover, .pagination a:hover { background: var(--cobalt); color: #fff; border-color: var(--cobalt); }

.skip-link { position: absolute; left: -9999px; }
.screen-reader-text { clip: rect(1px, 1px, 1px, 1px); position: absolute !important; height: 1px; width: 1px; overflow: hidden; word-wrap: normal !important; }

/* Posts grid (archive / category / blog index) */
.itsi-posts { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.5rem; padding: 2rem clamp(1.2rem,4vw,2.8rem); max-width: var(--max); margin: 0 auto; }
@media(max-width:900px) { .itsi-posts { grid-template-columns: repeat(2, 1fr); } }
@media(max-width:600px) { .itsi-posts { grid-template-columns: 1fr; } }
.itsi-post-card { background: #fff; border: 1px solid #dbe9ff; border-radius: 22px; overflow: hidden; transition: all .32s var(--ease); display: flex; flex-direction: column; }
.itsi-post-card:hover { box-shadow: 0 20px 64px rgba(12,61,122,.13); transform: translateY(-6px); border-color: #99bcee; }
.itsi-post-thumb { aspect-ratio: 16/10; background: linear-gradient(135deg, var(--royal), var(--cobalt)); display: flex; align-items: center; justify-content: center; font-size: 3rem; color: #fff; }
.itsi-post-thumb img { width: 100%; height: 100%; object-fit: cover; }
.itsi-post-body { padding: 1.5rem; flex: 1; display: flex; flex-direction: column; }
.itsi-post-title { font-family: 'Cormorant Garamond', serif; font-size: 1.15rem; font-weight: 700; color: var(--tx-dark); line-height: 1.4; margin-bottom: .55rem; }
.itsi-post-title a { color: inherit; border: 0; }
.itsi-post-excerpt { font-size: .85rem; color: var(--tx-mid); line-height: 1.65; margin-bottom: 1rem; flex: 1; }
.itsi-post-meta { font-size: .72rem; color: var(--tx-soft); display: flex; gap: .8rem; }

/* ═══════════════════════════
   POST CARD (itsi-posts grid item)
═══════════════════════════ */
.itsi-post { background: #fff; border: 1px solid #dbe9ff; border-radius: 20px; overflow: hidden; transition: all .3s var(--ease); display: flex; flex-direction: column; }
.itsi-post:hover { box-shadow: 0 16px 52px rgba(12,61,122,.13); transform: translateY(-5px); border-color: #99bcee; }
.itsi-post-img { position: relative; height: 200px; display: block; overflow: hidden; }
.itsi-post-img img { width: 100%; height: 100%; object-fit: cover; transition: transform .4s var(--ease); }
.itsi-post:hover .itsi-post-img img { transform: scale(1.06); }
.itsi-post-fallback { width: 100%; height: 100%; display: flex; align-items: center; justify-content: center; font-size: 3.4rem; background: linear-gradient(135deg, #04162E, #1459B3); }
.itsi-post-cat { position: absolute; top: .9rem; left: .9rem; z-index: 1; padding: .26rem .72rem; border-radius: 7px; font-size: .66rem; font-weight: 800; text-transform: uppercase; letter-spacing: .08em; background: var(--cobalt); color: #fff; }
.itsi-post-body { padding: 1.5rem; flex: 1; display: flex; flex-direction: column; }
.itsi-post-meta { font-size: .73rem; color: var(--tx-soft); margin-bottom: .65rem; }
.itsi-post-title { font-family: 'Cormorant Garamond', serif; font-size: 1.12rem; font-weight: 700; color: var(--tx-dark); line-height: 1.4; margin-bottom: .55rem; flex: 1; }
.itsi-post-title a { color: inherit; border-bottom: 0; }
.itsi-post-title a:hover { color: var(--cobalt); }
.itsi-post-excerpt { font-size: .85rem; color: var(--tx-mid); line-height: 1.7; margin-bottom: 1.1rem; display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical; overflow: hidden; }
.itsi-post-more { display: inline-flex; align-items: center; gap: .35rem; font-size: .8rem; font-weight: 700; color: var(--cobalt); margin-top: auto; }
.itsi-post-more:hover { gap: .55rem; }

@media (max-width: 600px) { .itsi-posts { grid-template-columns: 1fr; } }

/* ═══════════════════════════
   PAGE BANNER (page.php / single.php / index.php header)
═══════════════════════════ */
.page-banner {
  background: linear-gradient(155deg, var(--ink) 0%, var(--navy) 50%, var(--deep) 100%);
  position: relative; overflow: hidden;
  padding: clamp(5rem, 9vw, 8rem) 0 clamp(3rem, 5vw, 4.5rem);
  margin-bottom: 0;
}
.page-banner::before {
  content: ''; position: absolute; inset: 0;
  background: radial-gradient(ellipse 60% 50% at 70% 30%, rgba(20,89,179,.25) 0%, transparent 65%);
  pointer-events: none;
}
.page-banner::after {
  content: ''; position: absolute; inset: 0; opacity: .025;
  background-image: radial-gradient(circle, rgba(117,192,245,1) 1.2px, transparent 1.2px);
  background-size: 40px 40px; pointer-events: none;
}
.page-banner .container { position: relative; z-index: 1; }
.page-banner-h1 {
  font-family: 'Cormorant Garamond', serif;
  font-size: clamp(2.2rem, 4.5vw, 3.6rem);
  font-weight: 700; color: #fff; line-height: 1.15;
  margin: .9rem 0 .7rem; max-width: 880px;
}
.page-banner-h1 em, .page-banner-h1 .gold-line {
  font-style: italic; color: var(--gold-lt);
  background: linear-gradient(90deg, var(--gold-lt) 0%, var(--gold) 100%);
  -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent;
}
.page-banner-sub { color: rgba(255,255,255,.55); font-size: .95rem; display: flex; gap: .55rem; flex-wrap: wrap; align-items: center; }

/* ═══════════════════════════
   SINGLE PAGE / POST layout
═══════════════════════════ */
.itsi-page { max-width: 860px; margin: 0 auto; padding: 0 clamp(1.2rem,4vw,2.8rem) 4rem; }
.itsi-page-feat { margin: 2.5rem 0 2rem; border-radius: 18px; overflow: hidden; }
.itsi-page-feat img { width: 100%; height: auto; display: block; }
.itsi-entry { font-size: 1rem; color: var(--tx-body); line-height: 1.9; }
.itsi-entry p { margin-bottom: 1.15rem; }
.itsi-entry h2, .itsi-entry h3 { font-family: 'Cormorant Garamond', serif; color: var(--tx-dark); margin: 2.2rem 0 1rem; }
.itsi-entry a { color: var(--cobalt); font-weight: 600; border-bottom: 1.5px solid var(--frost); }
.itsi-entry a:hover { border-color: var(--cobalt); }

.itsi-post-footer { display: flex; align-items: center; justify-content: space-between; gap: 1rem; flex-wrap: wrap; padding: 1.8rem 0 0; border-top: 1px solid var(--frost); margin-top: 2.5rem; }
.itsi-tags { display: flex; flex-wrap: wrap; gap: .5rem; align-items: center; }
.itsi-tags a { padding: .32rem .8rem; border-radius: 30px; background: var(--frost); color: var(--royal); font-size: .76rem; font-weight: 600; border-bottom: 0; }
.itsi-tags a:hover { background: var(--cobalt); color: #fff; }
.itsi-tags-lbl { font-size: .8rem; color: var(--tx-soft); font-weight: 700; }
.edit-link a { color: var(--cobalt); font-size: .82rem; font-weight: 600; }

/* Post navigation (prev/next) */
.itsi-post-nav { max-width: 860px; margin: 2rem auto 0; padding: 0 clamp(1.2rem,4vw,2.8rem) 4rem; display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }
.ipn { background: var(--surface); border: 1px solid #dbe9ff; border-radius: 14px; padding: 1.1rem 1.3rem; transition: all .25s; display: flex; flex-direction: column; gap: .25rem; border-bottom-width: 1px; }
.ipn:hover { border-color: var(--azure); box-shadow: 0 6px 22px rgba(12,61,122,.1); transform: translateY(-2px); }
.ipn-lbl { font-size: .73rem; font-weight: 800; text-transform: uppercase; letter-spacing: .1em; color: var(--cobalt); }
.ipn-ttl { font-size: .88rem; font-weight: 600; color: var(--tx-dark); line-height: 1.45; }
.ipn-next { text-align: right; align-items: flex-end; }
@media (max-width: 600px) { .itsi-post-nav { grid-template-columns: 1fr; } }

/* ═══════════════════════════
   EMPTY STATE
═══════════════════════════ */
.itsi-empty { text-align: center; padding: 4rem 1rem; max-width: 540px; margin: 0 auto; }
.itsi-empty-ic { font-size: 4rem; margin-bottom: 1rem; }
.itsi-empty h2 { font-family: 'Cormorant Garamond', serif; font-size: 1.8rem; color: var(--tx-dark); margin-bottom: .6rem; }
.itsi-empty p { color: var(--tx-mid); margin-bottom: 1.8rem; }

/* ═══════════════════════════
   PAGINATION wrap
═══════════════════════════ */
.itsi-pagination { max-width: var(--max); margin: 1rem auto 3rem; padding: 0 clamp(1.2rem,4vw,2.8rem); display: flex; justify-content: center; }
.itsi-pagination .nav-links { display: flex; gap: .55rem; flex-wrap: wrap; }
.itsi-pagination .page-numbers { display: inline-flex; align-items: center; justify-content: center; min-width: 38px; height: 38px; padding: 0 .85rem; border-radius: 10px; background: var(--surface); border: 1px solid #dbe9ff; color: var(--royal); font-weight: 700; font-size: .85rem; }
.itsi-pagination .page-numbers.current { background: var(--cobalt); color: #fff; border-color: var(--cobalt); }
.itsi-pagination .page-numbers:hover:not(.current) { background: var(--cobalt); color: #fff; border-color: var(--cobalt); }
.itsi-pagination .page-numbers.dots { background: transparent; border: none; }

/* ═══════════════════════════════════════════════════════════
   FRONT PAGE — Section utilities & components
═══════════════════════════════════════════════════════════ */
.gold-line {
  font-style: italic;
  background: linear-gradient(90deg, var(--gold-lt) 0%, var(--gold) 100%);
  -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent;
}
.section { padding: clamp(4.5rem, 9vw, 7.5rem) 0; }
.section-info { background: var(--surface); }
.section-pengumuman { background: #fff; }
.section-artikel { background: var(--surface); }
.section-mitra { background: #fff; }
.section-infopub { background: var(--navy); color: #fff; position: relative; overflow: hidden; }
.section-infopub .sec-h2 { color: #fff; }
.section-infopub .eyebrow { color: rgba(255,255,255,.7); }
.section-infopub .eyebrow .ey-dot { background: var(--gold-lt); }
.section-infopub .sec-sub { color: rgba(255,255,255,.55); }
.section-infopub .btn-outline { color: #fff; border-color: rgba(255,255,255,.3); }
.section-infopub .btn-outline:hover { background: rgba(255,255,255,.08); border-color: var(--gold-lt); color: var(--gold-lt); }

.sec-head { display: flex; align-items: flex-end; justify-content: space-between; gap: 2rem; margin-bottom: 2.5rem; flex-wrap: wrap; }
.sec-head-center { flex-direction: column; align-items: center; text-align: center; }
.sec-h2 { font-family: 'Cormorant Garamond', serif; font-size: clamp(2rem, 3.5vw, 2.8rem); font-weight: 700; color: var(--tx-dark); line-height: 1.18; margin: .9rem 0 0; }
.sec-h2 em, .sec-h2 .gold-line { font-style: italic; color: var(--azure); }
.sec-sub { color: var(--tx-mid); font-size: .95rem; max-width: 580px; line-height: 1.75; }

/* ─── HERO (Component) ─── */
.hero { position: relative; overflow: hidden; background: var(--ink); min-height: 92vh; display: flex; align-items: center; }
.hero-bg { position: absolute; inset: 0; }
.hero-mesh { position: absolute; inset: -10%; background: radial-gradient(ellipse 60% 55% at 65% 25%, rgba(12,61,122,.55) 0%, transparent 65%), radial-gradient(ellipse 45% 40% at 12% 70%, rgba(8,39,79,.75) 0%, transparent 60%); animation: meshBreathe 14s ease-in-out infinite alternate; }
@keyframes meshBreathe { 0% { opacity: .9; transform: scale(1); } 100% { opacity: 1; transform: scale(1.05); } }
.hero-dots { position: absolute; inset: 0; opacity: .028; background-image: radial-gradient(circle, rgba(117,192,245,1) 1.2px, transparent 1.2px); background-size: 48px 48px; }
.hero-grid { display: grid; grid-template-columns: 1.2fr 1fr; gap: clamp(2.5rem, 5vw, 5rem); align-items: center; padding-block: clamp(7rem, 12vh, 10rem) clamp(4rem, 8vh, 7rem); }
.hero-text { position: relative; z-index: 2; }
.hero-eyebrow { display: inline-flex; align-items: center; gap: .55rem; padding: .42rem 1rem; border-radius: 30px; background: var(--gw); border: 1px solid var(--gb); color: rgba(255,255,255,.78); font-size: .75rem; font-weight: 600; letter-spacing: .04em; }
.ey-dot { display: inline-block; width: 6px; height: 6px; border-radius: 50%; background: var(--cerulean); }
.hero-h1 { font-family: 'Cormorant Garamond', serif; font-size: clamp(2.6rem, 5vw, 4.5rem); font-weight: 700; color: #fff; line-height: 1.08; margin: 1.1rem 0 1.4rem; }
.hero-h1 .gold-line { font-style: italic; }
.hero-p { font-size: 1.02rem; line-height: 1.85; color: rgba(255,255,255,.58); max-width: 510px; }
.hero-cta { display: flex; gap: 1rem; flex-wrap: wrap; margin-top: 2rem; }
.hero-stats { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1rem; margin-top: 2.5rem; }
.hs { background: rgba(255,255,255,.04); border: 1px solid rgba(255,255,255,.08); border-radius: 14px; padding: 1.1rem 1rem; }
.hs-num { font-family: 'Cormorant Garamond', serif; font-size: 1.6rem; color: var(--cerulean); line-height: 1; font-weight: 700; }
.hs-lbl { font-size: .72rem; color: rgba(255,255,255,.45); margin-top: .3rem; }

.hero-right { position: relative; z-index: 2; }
.hero-card { background: linear-gradient(155deg, rgba(10,40,90,.7) 0%, rgba(4,22,46,.85) 100%); border: 1px solid rgba(255,255,255,.12); border-radius: 22px; padding: 1.75rem; backdrop-filter: blur(18px); }
.hc-stats { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; margin-bottom: 1.4rem; }
.hc-stat { background: rgba(255,255,255,.05); border: 1px solid rgba(255,255,255,.08); border-radius: 13px; padding: 1.1rem 1rem; }
.hc-num { font-family: 'Cormorant Garamond', serif; font-size: 1.7rem; color: var(--cerulean); line-height: 1; font-weight: 700; }
.hc-lbl { font-size: .7rem; color: rgba(255,255,255,.45); margin-top: .25rem; }
.hc-sep { height: 1px; background: rgba(255,255,255,.07); margin-bottom: 1.3rem; }
.hc-ann-ttl { font-size: .68rem; font-weight: 800; letter-spacing: .13em; text-transform: uppercase; color: var(--gold-lt); margin-bottom: .75rem; }
.hc-ann-item { display: flex; align-items: flex-start; gap: .7rem; padding: .5rem .55rem; border-radius: 10px; transition: background .2s; text-decoration: none; }
.hc-ann-item:hover { background: rgba(255,255,255,.06); }
.hc-ann-dot { width: 7px; height: 7px; border-radius: 50%; background: var(--cerulean); flex-shrink: 0; margin-top: 6px; }
.hc-ann-date { font-size: .65rem; font-weight: 800; color: var(--sky); min-width: 40px; flex-shrink: 0; }
.hc-ann-text { font-size: .79rem; color: rgba(255,255,255,.72); line-height: 1.45; }

@media (max-width: 1024px) {
  .hero-grid { grid-template-columns: 1fr; }
  .hero-stats { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 600px) {
  .hero-stats { grid-template-columns: 1fr 1fr; }
  .hero-cta { flex-direction: column; }
  .hero-cta .btn { justify-content: center; }
}

/* ─── SAMBUTAN (Component) ─── */
.section-sambutan { background: var(--surface); }
.sam-text .sec-h2 { margin: .9rem 0 0; }
.sam-blockquote { font-family: 'Cormorant Garamond', serif; font-style: italic; font-size: clamp(1.15rem, 1.7vw, 1.4rem); line-height: 1.68; color: var(--tx-dark); margin: 1.2rem 0 1.5rem; padding-left: 1.4rem; border-left: 3px solid var(--azure); }
.sam-body { font-size: .95rem; color: var(--tx-mid); line-height: 1.85; }
.sam-body p + p { margin-top: .9rem; }
.sam-more { display: inline-flex; align-items: center; gap: .45rem; color: var(--cobalt); font-weight: 700; font-size: .88rem; margin-top: 1.5rem; padding-bottom: .25rem; border-bottom: 2px solid var(--frost); transition: all .2s; }
.sam-more:hover { border-color: var(--cobalt); gap: .65rem; }

.sam-name { font-family: 'Cormorant Garamond', serif; font-size: 1.15rem; font-weight: 700; color: #fff; margin-bottom: .3rem; }
.sam-pos { font-size: .78rem; color: rgba(255,255,255,.55); margin-bottom: 1.2rem; }
.sam-badge { display: inline-block; background: rgba(255,255,255,.1); border: 1px solid rgba(255,255,255,.2); color: rgba(255,255,255,.82); padding: .33rem .9rem; border-radius: 8px; font-size: .73rem; font-weight: 700; }
.sam-dots { display: flex; align-items: center; justify-content: center; gap: .5rem; margin-top: 1.3rem; }
.sam-dots span { font-size: .7rem; color: rgba(255,255,255,.38); }
.sam-dots i { width: 4px; height: 4px; border-radius: 50%; background: var(--gold-lt); display: block; }

@media (max-width: 1024px) { .sam-grid { grid-template-columns: 1fr; } }

/* ─── INFOGRAFIS small bar (used inside component) ─── */
.ig-item { text-align: center; padding: 1.5rem 1rem; }
.ig-ic { font-size: 2.2rem; margin-bottom: .85rem; display: block; }
.ig-num { font-family: 'Cormorant Garamond', serif; font-size: 2.3rem; font-weight: 700; color: var(--cerulean); line-height: 1; }
.ig-lbl { font-size: .77rem; color: rgba(255,255,255,.52); margin-top: .38rem; line-height: 1.45; }

/* ─── BERITA list (Component) ─── */
.news-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.5rem; }
.news-card { background: #fff; border: 1px solid #dbe9ff; border-radius: 20px; overflow: hidden; transition: all .32s var(--ease); display: flex; flex-direction: column; }
.news-card:hover { box-shadow: 0 20px 64px rgba(12,61,122,.13); transform: translateY(-6px); border-color: #99bcee; }
.news-img { position: relative; height: 200px; display: block; overflow: hidden; background: linear-gradient(135deg, #04162E, #1459B3); }
.news-img img { width: 100%; height: 100%; object-fit: cover; transition: transform .4s var(--ease); }
.news-card:hover .news-img img { transform: scale(1.06); }
.news-fallback { width: 100%; height: 100%; display: flex; align-items: center; justify-content: center; font-size: 4rem; }
.news-cat { position: absolute; top: .95rem; left: .95rem; z-index: 1; padding: .28rem .7rem; border-radius: 7px; font-size: .66rem; font-weight: 800; text-transform: uppercase; letter-spacing: .08em; background: var(--cobalt); color: #fff; }
.news-body { padding: 1.5rem; flex: 1; display: flex; flex-direction: column; }
.news-meta { font-size: .73rem; color: var(--tx-soft); display: flex; gap: 1rem; margin-bottom: .7rem; }
.news-title { font-family: 'Cormorant Garamond', serif; font-size: 1.1rem; font-weight: 700; color: var(--tx-dark); line-height: 1.42; margin-bottom: .55rem; }
.news-title a { color: inherit; }
.news-title a:hover { color: var(--cobalt); }
.news-excerpt { font-size: .85rem; color: var(--tx-mid); line-height: 1.7; margin-bottom: 1rem; flex: 1; display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical; overflow: hidden; }
.news-more { display: inline-flex; align-items: center; gap: .35rem; font-size: .8rem; font-weight: 700; color: var(--cobalt); margin-top: auto; transition: gap .2s; }
.news-more:hover { gap: .55rem; }

@media (max-width: 900px) { .news-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 600px) { .news-grid { grid-template-columns: 1fr; } }

/* ─── PENGUMUMAN list (Component) ─── */
.ann-list { display: flex; flex-direction: column; gap: 1.1rem; }
.ann-item { display: flex; align-items: center; gap: 1.3rem; background: var(--surface); border: 1px solid #dbe9ff; border-radius: 16px; padding: 1.4rem 1.5rem; text-decoration: none; color: inherit; transition: all .3s var(--ease); }
.ann-item:hover { border-color: #99bcee; box-shadow: 0 12px 36px rgba(12,61,122,.1); transform: translateX(4px); }
.ann-date { flex-shrink: 0; text-align: center; background: linear-gradient(135deg, var(--royal), var(--cobalt)); border-radius: 12px; padding: .75rem .9rem; min-width: 70px; color: #fff; }
.ann-d { font-family: 'Cormorant Garamond', serif; font-size: 1.8rem; font-weight: 700; line-height: 1; }
.ann-m { font-size: .7rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; margin-top: .25rem; opacity: .85; }
.ann-body { flex: 1; min-width: 0; }
.ann-badge { display: inline-block; background: linear-gradient(90deg, #c92e2e, #ff6b35); color: #fff; padding: .2rem .65rem; border-radius: 6px; font-size: .65rem; font-weight: 800; letter-spacing: .08em; margin-bottom: .55rem; }
.ann-tag { display: inline-block; background: var(--frost); color: var(--royal); padding: .2rem .65rem; border-radius: 6px; font-size: .65rem; font-weight: 800; letter-spacing: .08em; margin-bottom: .55rem; }
.ann-title { font-size: 1rem; font-weight: 700; color: var(--tx-dark); line-height: 1.45; margin-bottom: .35rem; }
.ann-excerpt { font-size: .83rem; color: var(--tx-mid); line-height: 1.65; margin-bottom: .55rem; }
.ann-meta { font-size: .71rem; color: var(--tx-soft); }
.ann-arrow { font-size: 1.3rem; color: var(--azure); flex-shrink: 0; transition: transform .2s; }
.ann-item:hover .ann-arrow { transform: translateX(4px); }

@media (max-width: 700px) { .ann-item { flex-direction: column; align-items: flex-start; } .ann-date { align-self: flex-start; } }

/* ─── ARTIKEL (Component) ─── */
.art-cat { position: absolute; top: .9rem; left: .9rem; z-index: 1; padding: .26rem .7rem; border-radius: 7px; font-size: .65rem; font-weight: 800; text-transform: uppercase; letter-spacing: .08em; background: var(--cobalt); color: #fff; }
.art-img { position: relative; height: 168px; display: block; overflow: hidden; background: linear-gradient(135deg, #04162E, #1459B3); }
.art-img img { width: 100%; height: 100%; object-fit: cover; transition: transform .4s var(--ease); }
.art-card:hover .art-img img { transform: scale(1.06); }
.art-fallback { width: 100%; height: 100%; display: flex; align-items: center; justify-content: center; font-size: 3rem; }
.art-body { padding: 1.5rem; flex: 1; display: flex; flex-direction: column; }
.art-meta { font-size: .73rem; color: var(--tx-soft); display: flex; gap: 1rem; margin-bottom: .7rem; }
.art-title { font-family: 'Cormorant Garamond', serif; font-size: 1.05rem; font-weight: 700; color: var(--tx-dark); line-height: 1.45; margin-bottom: .55rem; }
.art-title a { color: inherit; }
.art-excerpt { font-size: .83rem; color: var(--tx-mid); line-height: 1.7; margin-bottom: 1rem; flex: 1; display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical; overflow: hidden; }
.art-more { display: inline-flex; align-items: center; gap: .35rem; font-size: .79rem; font-weight: 700; color: var(--cobalt); margin-top: auto; transition: gap .2s; }
.art-more:hover { gap: .55rem; }

/* ─── MITRA (Component) ─── */
.mitra-grid { display: grid; grid-template-columns: repeat(6, 1fr); gap: 1rem; }
.mitra-card { display: flex; flex-direction: column; align-items: center; justify-content: center; gap: .6rem; padding: 1.4rem 1rem; border-radius: 16px; background: var(--surface); border: 1.5px solid #dbe9ff; transition: all .25s; text-align: center; }
.mitra-card:hover { border-color: #99bcee; box-shadow: 0 12px 36px rgba(12,61,122,.1); transform: translateY(-4px); }
.mitra-logo { height: 50px; display: flex; align-items: center; justify-content: center; }
.mitra-logo img { max-width: 100%; max-height: 100%; object-fit: contain; }
.mitra-initial { font-size: 1.3rem; font-weight: 800; color: var(--royal); width: 46px; height: 46px; border-radius: 12px; background: linear-gradient(135deg,#e6f0ff,#dbe9ff); display: flex; align-items: center; justify-content: center; }
.mitra-name { font-size: .82rem; font-weight: 700; color: var(--tx-dark); line-height: 1.3; }

@media (max-width: 1024px) { .mitra-grid { grid-template-columns: repeat(4, 1fr); } }
@media (max-width: 700px) { .mitra-grid { grid-template-columns: repeat(2, 1fr); } }

/* ─── INFORMASI PUBLIK (Component) ─── */
.kip-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.2rem; }
.kip-card { display: flex; align-items: center; gap: 1rem; background: rgba(255,255,255,.05); border: 1px solid rgba(255,255,255,.1); border-radius: 14px; padding: 1.2rem 1.3rem; color: #fff; text-decoration: none; transition: all .25s var(--ease); }
.kip-card:hover { background: rgba(255,255,255,.1); border-color: var(--gold-lt); transform: translateY(-3px); }
.kip-ic { font-size: 1.9rem; flex-shrink: 0; }
.kip-body { flex: 1; min-width: 0; }
.kip-cat { font-size: .65rem; font-weight: 800; letter-spacing: .1em; text-transform: uppercase; color: var(--gold-lt); margin-bottom: .35rem; display: inline-block; }
.kip-title { font-size: .88rem; font-weight: 600; color: #fff; line-height: 1.45; margin-bottom: .4rem; }
.kip-excerpt { font-size: .75rem; color: rgba(255,255,255,.45); line-height: 1.55; margin-bottom: .55rem; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.kip-meta { font-size: .69rem; color: rgba(255,255,255,.4); display: flex; gap: .8rem; flex-wrap: wrap; }
.kip-go { font-size: 1.2rem; color: var(--gold-lt); flex-shrink: 0; transition: transform .2s; }
.kip-card:hover .kip-go { transform: translateX(4px); }

@media (max-width: 900px) { .kip-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 600px) { .kip-grid { grid-template-columns: 1fr; } }

/* ═══════════════════════════════════════════════════════════
   ARC-* (Archive / page-banner on dark) layouts
═══════════════════════════════════════════════════════════ */
.arc-hero { position: relative; overflow: hidden; background: var(--ink); padding: clamp(5.5rem, 10vw, 9rem) 0 clamp(3.5rem, 6vw, 5rem); }
.arc-hero-bg { position: absolute; inset: 0; }
.arc-hero-mesh { position: absolute; inset: -10%; background: radial-gradient(ellipse 60% 50% at 70% 25%, rgba(12,61,122,.5) 0%, transparent 65%), radial-gradient(ellipse 50% 45% at 15% 75%, rgba(8,39,79,.7) 0%, transparent 60%); animation: meshBreathe 14s ease-in-out infinite alternate; }
.arc-hero-dots { position: absolute; inset: 0; opacity: .028; background-image: radial-gradient(circle, rgba(117,192,245,1) 1.2px, transparent 1.2px); background-size: 48px 48px; }
.arc-hero-inner { position: relative; z-index: 2; max-width: 880px; }
.arc-h1 { font-family: 'Cormorant Garamond', serif; font-size: clamp(2.4rem, 5vw, 4rem); font-weight: 700; color: #fff; line-height: 1.12; margin: .9rem 0 .7rem; }
.arc-h1 .gold-line { font-style: italic; }
.arc-sub { font-size: 1.02rem; line-height: 1.78; color: rgba(255,255,255,.6); max-width: 620px; margin-bottom: 2rem; }

.arc-search { position: relative; display: flex; align-items: center; background: rgba(255,255,255,.08); border: 1.5px solid rgba(255,255,255,.18); border-radius: 16px; padding: .4rem; max-width: 640px; backdrop-filter: blur(12px); margin-bottom: 2rem; }
.arc-search-ic { padding: 0 .75rem .2rem; color: rgba(255,255,255,.4); font-size: 1.1rem; }
.arc-search-inp { flex: 1; background: transparent; border: 0; outline: none; color: #fff; font-family: inherit; font-size: .98rem; padding: .7rem 0; }
.arc-search-inp::placeholder { color: rgba(255,255,255,.4); }
.arc-search-btn { background: linear-gradient(135deg, var(--azure), var(--royal)); color: #fff; border: 0; padding: .7rem 1.4rem; border-radius: 11px; font-weight: 700; font-size: .85rem; cursor: pointer; transition: all .22s; }
.arc-search-btn:hover { transform: translateY(-1px); box-shadow: 0 8px 22px rgba(20,89,179,.4); }

.arc-stats-row { display: flex; gap: 1.2rem; flex-wrap: wrap; }
.arc-stat { background: rgba(255,255,255,.04); border: 1px solid rgba(255,255,255,.08); border-radius: 14px; padding: 1rem 1.4rem; min-width: 140px; }
.arc-stat-n { display: block; font-family: 'Cormorant Garamond', serif; font-size: 1.8rem; color: var(--cerulean); line-height: 1; font-weight: 700; }
.arc-stat-l { display: block; font-size: .73rem; color: rgba(255,255,255,.5); margin-top: .3rem; }

.arc-filter { padding: 1.6rem 0; background: var(--surface); border-bottom: 1px solid var(--frost); }
.arc-filter-wrap { display: flex; align-items: center; gap: .55rem; flex-wrap: wrap; }
.arc-filter-lbl { font-size: .78rem; font-weight: 800; letter-spacing: .12em; text-transform: uppercase; color: var(--tx-soft); margin-right: .55rem; }
.arc-chip { padding: .5rem 1.1rem; border-radius: 30px; font-size: .8rem; font-weight: 600; background: #fff; border: 1.5px solid #dbe9ff; color: var(--tx-mid); cursor: pointer; transition: all .22s; display: inline-flex; align-items: center; gap: .4rem; }
.arc-chip:hover:not(.on) { border-color: var(--azure); color: var(--cobalt); }
.arc-chip.on { background: var(--cobalt); border-color: var(--cobalt); color: #fff; box-shadow: 0 4px 14px rgba(20,89,179,.28); }
.chip-count { background: rgba(0,0,0,.12); color: inherit; padding: 0 .5rem; border-radius: 30px; font-size: .68rem; font-weight: 800; min-width: 22px; text-align: center; }
.arc-chip.on .chip-count { background: rgba(255,255,255,.25); }
.arc-filter-wrap-kat { gap: .65rem; }

.arc-section { background: var(--surface); padding: 3rem 0 4rem; }
.arc-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.5rem; }
.arc-card { background: #fff; border: 1px solid #dbe9ff; border-radius: 20px; overflow: hidden; transition: all .3s var(--ease); display: flex; flex-direction: column; }
.arc-card:hover { box-shadow: 0 16px 52px rgba(12,61,122,.13); transform: translateY(-5px); border-color: #99bcee; }
.arc-card-img { position: relative; height: 200px; display: block; overflow: hidden; background: linear-gradient(135deg, #04162E, #1459B3); }
.arc-card-img img { width: 100%; height: 100%; object-fit: cover; transition: transform .4s var(--ease); }
.arc-card:hover .arc-card-img img { transform: scale(1.06); }
.arc-card-fallback { width: 100%; height: 100%; display: flex; align-items: center; justify-content: center; font-size: 3.4rem; }
.arc-card-cat { position: absolute; top: .9rem; left: .9rem; z-index: 1; padding: .26rem .7rem; border-radius: 7px; font-size: .66rem; font-weight: 800; text-transform: uppercase; letter-spacing: .08em; background: var(--cobalt); color: #fff; }
.arc-card-body { padding: 1.5rem; flex: 1; display: flex; flex-direction: column; }
.arc-card-meta { font-size: .73rem; color: var(--tx-soft); display: flex; gap: 1rem; flex-wrap: wrap; margin-bottom: .65rem; }
.arc-card-title { font-family: 'Cormorant Garamond', serif; font-size: 1.12rem; font-weight: 700; color: var(--tx-dark); line-height: 1.4; margin-bottom: .55rem; }
.arc-card-title a { color: inherit; }
.arc-card-excerpt { font-size: .85rem; color: var(--tx-mid); line-height: 1.7; margin-bottom: 1.1rem; flex: 1; display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical; overflow: hidden; }
.arc-card-more { display: inline-flex; align-items: center; gap: .35rem; font-size: .8rem; font-weight: 700; color: var(--cobalt); margin-top: auto; transition: gap .2s; }
.arc-card-more:hover { gap: .55rem; }

@media (max-width: 900px) { .arc-grid { grid-template-columns: 1fr 1fr; } .kip-grid-arc { grid-template-columns: 1fr 1fr; } }
@media (max-width: 600px) { .arc-grid { grid-template-columns: 1fr; } .kip-grid-arc { grid-template-columns: 1fr; } .arc-stats-row { gap: .6rem; } .arc-stat { min-width: 0; flex: 1; } }

.arc-pagination { padding: 2.5rem 0 0; display: flex; justify-content: center; }
.arc-pagination .page-numbers, .arc-pagination a, .arc-pagination span { display: inline-flex; align-items: center; justify-content: center; min-width: 38px; height: 38px; padding: 0 .85rem; margin: 0 .2rem; border-radius: 10px; background: #fff; border: 1.5px solid #dbe9ff; color: var(--royal); font-weight: 700; font-size: .85rem; text-decoration: none; }
.arc-pagination .current { background: var(--cobalt); color: #fff; border-color: var(--cobalt); }
.arc-pagination a:hover:not(.current) { background: var(--cobalt); color: #fff; border-color: var(--cobalt); }

.arc-empty { text-align: center; padding: 5rem 1rem; max-width: 460px; margin: 0 auto; }
.arc-empty-ic { font-size: 4.5rem; margin-bottom: 1rem; }
.arc-empty h3 { font-family: 'Cormorant Garamond', serif; font-size: 1.7rem; color: var(--tx-dark); margin-bottom: .55rem; }
.arc-empty p { color: var(--tx-mid); }

.arc-cta { padding: 3rem 0 5rem; }
.arc-cta-card { background: linear-gradient(135deg, var(--royal), var(--cobalt)); border-radius: 22px; padding: clamp(2rem, 4vw, 3rem); display: grid; grid-template-columns: 1fr 1fr; gap: 2rem; align-items: center; }
.arc-cta-text .eyebrow { color: rgba(255,255,255,.65); }
.arc-cta-text .eyebrow .ey-dot { background: var(--gold-lt); }
.arc-cta-text h3 { font-family: 'Cormorant Garamond', serif; font-size: clamp(1.5rem, 2.4vw, 2rem); color: #fff; font-weight: 700; margin: .8rem 0 .6rem; line-height: 1.25; }
.arc-cta-text p { color: rgba(255,255,255,.62); font-size: .9rem; }
.arc-cta-form { display: flex; gap: .55rem; }
.arc-cta-inp { flex: 1; background: rgba(255,255,255,.95); border: 0; padding: .85rem 1.1rem; border-radius: 12px; color: var(--tx-dark); font-family: inherit; font-size: .9rem; outline: none; }
.arc-cta-inp::placeholder { color: var(--tx-soft); }
.arc-cta-form .btn-primary { background: linear-gradient(135deg, var(--gold-lt), var(--gold)); color: var(--ink); box-shadow: 0 8px 22px rgba(191,155,48,.45); }
@media (max-width: 768px) { .arc-cta-card { grid-template-columns: 1fr; } .arc-cta-form { flex-direction: column; } }

/* Ann list in archive: list-style variant */
.ann-list-arc { gap: 1rem; }
.ann-list-arc .ann-item { background: #fff; }

/* Kip grid in archive: more spacious card */
.kip-grid-arc { grid-template-columns: repeat(3, 1fr); }
.kip-grid-arc .kip-card { background: rgba(255,255,255,.05); }

/* ═══════════════════════════════════════════════════════════
   FORM PERMOHONAN INFORMASI
═══════════════════════════════════════════════════════════ */
.arc-form-section { background: linear-gradient(155deg, var(--ink) 0%, var(--navy) 50%, var(--deep) 100%); padding: clamp(4rem, 8vw, 6rem) 0; position: relative; overflow: hidden; }
.arc-form-section::before { content: ''; position: absolute; inset: 0; background: radial-gradient(ellipse 50% 45% at 80% 30%, rgba(20,89,179,.2) 0%, transparent 65%); pointer-events: none; }
.form-card { position: relative; z-index: 1; background: rgba(255,255,255,.04); border: 1px solid rgba(255,255,255,.1); border-radius: 24px; padding: clamp(2rem, 4vw, 3.2rem); backdrop-filter: blur(18px); }
.form-head { text-align: center; margin-bottom: 2.5rem; }
.form-head .eyebrow { color: rgba(255,255,255,.65); }
.form-head .eyebrow .ey-dot { background: var(--gold-lt); }
.form-h2 { font-family: 'Cormorant Garamond', serif; font-size: clamp(1.8rem, 3.2vw, 2.4rem); color: #fff; font-weight: 700; line-height: 1.2; margin: .9rem 0 .7rem; }
.form-h2 .gold-line { font-style: italic; }
.form-sub { color: rgba(255,255,255,.58); font-size: .92rem; max-width: 640px; margin: 0 auto; line-height: 1.75; }
.form-sub strong { color: var(--gold-lt); }

.form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 1.1rem 1.2rem; }
.field-full { grid-column: 1 / -1; }
.field { display: flex; flex-direction: column; }
.field-lbl { font-size: .78rem; font-weight: 700; color: rgba(255,255,255,.78); margin-bottom: .45rem; }
.req { color: #ff7b7b; }
.field-inp { background: rgba(255,255,255,.06); border: 1.5px solid rgba(255,255,255,.15); border-radius: 12px; padding: .8rem 1rem; color: #fff; font-family: inherit; font-size: .92rem; outline: none; transition: all .22s; }
.field-inp::placeholder { color: rgba(255,255,255,.32); }
.field-inp:focus { border-color: var(--azure); background: rgba(255,255,255,.09); box-shadow: 0 0 0 3px rgba(20,89,179,.18); }
.field-textarea { resize: vertical; min-height: 90px; line-height: 1.55; }
.field-inp.is-invalid { border-color: #ff7b7b; background: rgba(255,123,123,.08); }

.field-check { display: flex; align-items: flex-start; gap: .65rem; padding: .9rem 1rem; background: rgba(255,255,255,.04); border: 1px dashed rgba(255,255,255,.15); border-radius: 12px; font-size: .85rem; color: rgba(255,255,255,.7); line-height: 1.55; cursor: pointer; }
.field-check input[type="checkbox"] { width: 18px; height: 18px; accent-color: var(--azure); flex-shrink: 0; margin-top: 2px; }
.form-actions { display: flex; gap: 1rem; justify-content: flex-end; flex-wrap: wrap; }
.form-actions .btn-outline { color: #fff; border-color: rgba(255,255,255,.3); }
.form-actions .btn-outline:hover { background: rgba(255,255,255,.08); border-color: rgba(255,255,255,.5); }
#formSubmitBtn { position: relative; min-width: 200px; }
#formSubmitBtn.is-loading { opacity: .7; pointer-events: none; }
#formSubmitBtn.is-loading::after { content: ''; position: absolute; right: 1rem; top: 50%; width: 14px; height: 14px; border: 2px solid currentColor; border-top-color: transparent; border-radius: 50%; transform: translateY(-50%); animation: formSpin .7s linear infinite; }
@keyframes formSpin { to { transform: translateY(-50%) rotate(360deg); } }

.form-foot { display: flex; align-items: flex-start; gap: 1rem; padding: 1.3rem 1.3rem; background: rgba(255,255,255,.04); border: 1px solid rgba(255,255,255,.08); border-radius: 13px; margin-top: 1.5rem; }
.form-foot-ic { font-size: 1.3rem; flex-shrink: 0; }
.form-foot p { color: rgba(255,255,255,.6); font-size: .83rem; line-height: 1.6; margin: 0; }
.form-foot a { color: var(--gold-lt); font-weight: 600; border-bottom: 1px solid currentColor; }

.form-success, .form-error { padding: 1.2rem 1.3rem; border-radius: 13px; margin-bottom: 1.5rem; display: flex; align-items: flex-start; gap: .8rem; }
.form-success { background: rgba(95,210,140,.12); border: 1px solid rgba(95,210,140,.4); color: #b6e7c7; }
.form-error   { background: rgba(255,123,123,.12); border: 1px solid rgba(255,123,123,.4); color: #ffc1c1; }
.form-success-ic, .form-error-ic { font-size: 1.4rem; flex-shrink: 0; }
.form-success h4, .form-error h4 { font-family: 'Cormorant Garamond', serif; font-size: 1.1rem; font-weight: 700; margin-bottom: .3rem; color: #fff; }
.form-success p, .form-error p { font-size: .85rem; line-height: 1.55; }

@media (max-width: 700px) { .form-grid { grid-template-columns: 1fr; } .form-actions { flex-direction: column-reverse; } .form-actions .btn { width: 100%; justify-content: center; } }

/* ═══════════════════════════════════════════════════════════
   SINGLE POST LAYOUT (newspaper style)
═══════════════════════════════════════════════════════════ */
.single-itsi { background: var(--surface); }
.breadcrumb-bar { background: var(--ink); padding: 1rem 0; border-bottom: 1px solid rgba(255,255,255,.05); }
.crumbs { display: flex; align-items: center; gap: .5rem; font-size: .8rem; color: rgba(255,255,255,.5); flex-wrap: wrap; }
.crumbs a { color: rgba(255,255,255,.55); transition: color .2s; }
.crumbs a:hover { color: var(--gold-lt); }
.crumbs svg { color: rgba(255,255,255,.25); }
.crumbs .cur { color: var(--cerulean); font-weight: 600; }

.single-hdr { background: linear-gradient(160deg, var(--ink) 0%, var(--navy) 50%, var(--deep) 100%); position: relative; padding: clamp(2.5rem, 4vw, 4rem) 0 clamp(3rem, 5vw, 4.5rem); }
.single-hdr::before { content: ''; position: absolute; inset: 0; background: radial-gradient(ellipse 60% 50% at 70% 30%, rgba(20,89,179,.2) 0%, transparent 65%); pointer-events: none; }
.single-hdr-inner { position: relative; z-index: 1; max-width: 900px; margin: 0 auto; text-align: center; }
.single-tags { display: flex; flex-wrap: wrap; gap: .5rem; justify-content: center; margin-bottom: 1.5rem; }
.single-tag { padding: .32rem .9rem; border-radius: 30px; background: var(--gw); border: 1px solid var(--gb); color: var(--cerulean); font-size: .72rem; font-weight: 800; letter-spacing: .08em; text-transform: uppercase; }
.single-tag.tag-ghost { color: rgba(255,255,255,.55); }
.single-h1 { font-family: 'Cormorant Garamond', serif; font-size: clamp(2.2rem, 4.2vw, 3.4rem); color: #fff; font-weight: 700; line-height: 1.18; margin: 0 0 1.2rem; }
.single-lead { color: rgba(255,255,255,.68); font-size: 1.1rem; line-height: 1.7; max-width: 720px; margin: 0 auto 1.8rem; }
.single-meta-bar { display: flex; align-items: center; justify-content: space-between; gap: 1.2rem; flex-wrap: wrap; padding-top: 1.5rem; border-top: 1px solid rgba(255,255,255,.08); }
.sm-author { display: flex; align-items: center; gap: .75rem; }
.sm-avatar { width: 42px; height: 42px; border-radius: 50%; background: linear-gradient(135deg, var(--cobalt), var(--azure)); color: #fff; display: flex; align-items: center; justify-content: center; font-weight: 800; font-family: 'Cormorant Garamond', serif; font-size: 1.2rem; }
.sm-name { color: #fff; font-weight: 700; font-size: .92rem; }
.sm-role { color: rgba(255,255,255,.5); font-size: .75rem; }
.sm-stats { display: flex; gap: 1.2rem; flex-wrap: wrap; font-size: .8rem; color: rgba(255,255,255,.55); }

.single-feat { margin: 2.5rem 0 0; }
.single-feat img { width: 100%; max-width: var(--max); max-height: 520px; object-fit: cover; border-radius: 22px; display: block; margin: 0 auto; box-shadow: 0 24px 60px rgba(0,0,0,.18); }

.single-body-wrap { padding: clamp(3rem, 5vw, 4.5rem) 0 clamp(3rem, 5vw, 5rem); }
.single-grid { display: grid; grid-template-columns: 1fr 320px; gap: clamp(2rem, 4vw, 3.5rem); align-items: start; }
.single-article { background: #fff; border: 1px solid #dbe9ff; border-radius: 22px; padding: clamp(1.8rem, 3vw, 2.8rem); }
.single-content { font-size: 1.02rem; line-height: 1.85; color: var(--tx-body); }
.single-content p { margin-bottom: 1.2rem; }
.single-content h2, .single-content h3 { font-family: 'Cormorant Garamond', serif; color: var(--tx-dark); margin: 2.2rem 0 1rem; line-height: 1.25; }
.single-content h2 { font-size: clamp(1.6rem, 2.4vw, 2rem); }
.single-content h3 { font-size: clamp(1.3rem, 2vw, 1.5rem); }
.single-content a { color: var(--cobalt); font-weight: 600; border-bottom: 1.5px solid var(--frost); }
.single-content a:hover { border-color: var(--cobalt); }
.single-content ul, .single-content ol { margin: 1rem 0 1rem 1.5rem; }
.single-content li { margin-bottom: .5rem; line-height: 1.7; }
.single-content img { border-radius: 14px; margin: 1.5rem 0; max-width: 100%; height: auto; }
.single-content blockquote { font-family: 'Cormorant Garamond', serif; font-style: italic; font-size: 1.3rem; color: var(--tx-dark); border-left: 3px solid var(--azure); padding-left: 1.4rem; margin: 1.5rem 0; }
.single-content code { background: var(--frost); color: var(--royal); padding: .15rem .4rem; border-radius: 5px; font-size: .9em; }
.single-content pre { background: var(--navy); color: #fff; padding: 1.25rem; border-radius: 12px; overflow-x: auto; }

.single-tags-foot { display: flex; align-items: center; flex-wrap: wrap; gap: .5rem; padding: 1.5rem 0; margin: 2rem 0; border-top: 1px solid var(--frost); border-bottom: 1px solid var(--frost); }
.tags-lbl { font-size: .82rem; color: var(--tx-soft); font-weight: 700; margin-right: .35rem; }
.tag-pill { padding: .3rem .8rem; border-radius: 30px; background: var(--frost); color: var(--royal); font-size: .75rem; font-weight: 600; border-bottom: 0; transition: all .2s; }
.tag-pill:hover { background: var(--cobalt); color: #fff; }

.share-bar { display: flex; align-items: center; flex-wrap: wrap; gap: 1rem; padding: 1.5rem; background: var(--surface); border: 1px solid #dbe9ff; border-radius: 16px; margin: 2rem 0; }
.share-lbl { font-size: .88rem; font-weight: 700; color: var(--tx-dark); }
.share-btns { display: flex; gap: .45rem; flex-wrap: wrap; }
.share-btn { padding: .5rem 1rem; border-radius: 10px; border: 0; font-size: .8rem; font-weight: 600; cursor: pointer; color: #fff; text-decoration: none; transition: all .22s; display: inline-flex; align-items: center; gap: .35rem; }
.share-btn:hover { transform: translateY(-2px); }
.sb-wa { background: #25d366; } .sb-fb { background: #1877f2; } .sb-tw { background: #1da1f2; } .sb-li { background: #0a66c2; } .sb-cp { background: var(--ink); }

.author-card { display: flex; align-items: center; gap: 1.2rem; background: linear-gradient(135deg, var(--royal), var(--cobalt)); border-radius: 18px; padding: 1.8rem; color: #fff; margin: 2rem 0; }
.ac-avatar { width: 72px; height: 72px; border-radius: 50%; background: rgba(255,255,255,.15); border: 2px solid rgba(255,255,255,.3); display: flex; align-items: center; justify-content: center; font-family: 'Cormorant Garamond', serif; font-size: 1.8rem; font-weight: 700; flex-shrink: 0; }
.ac-name { font-family: 'Cormorant Garamond', serif; font-size: 1.2rem; font-weight: 700; margin-bottom: .2rem; }
.ac-role { font-size: .8rem; color: rgba(255,255,255,.65); margin-bottom: .55rem; }
.ac-bio { font-size: .85rem; color: rgba(255,255,255,.78); line-height: 1.6; }

.related-section { padding: 2.5rem 0 0; }
.related-h3 { font-family: 'Cormorant Garamond', serif; font-size: 1.5rem; font-weight: 700; color: var(--tx-dark); margin-bottom: 1.5rem; }
.related-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.2rem; }
.related-card { background: var(--surface); border: 1px solid #dbe9ff; border-radius: 14px; overflow: hidden; text-decoration: none; color: inherit; transition: all .25s; display: flex; flex-direction: column; }
.related-card:hover { border-color: var(--azure); transform: translateY(-3px); box-shadow: 0 12px 30px rgba(12,61,122,.1); }
.related-img { aspect-ratio: 16/10; overflow: hidden; background: linear-gradient(135deg, var(--royal), var(--cobalt)); display: flex; align-items: center; justify-content: center; }
.related-img img { width: 100%; height: 100%; object-fit: cover; }
.related-fallback { font-size: 2.4rem; }
.related-body { padding: 1.1rem; }
.related-cat { font-size: .65rem; font-weight: 800; letter-spacing: .1em; text-transform: uppercase; color: var(--cobalt); }
.related-title { font-size: .9rem; font-weight: 600; color: var(--tx-dark); line-height: 1.4; margin: .35rem 0 .45rem; }
.related-meta { font-size: .72rem; color: var(--tx-soft); }

.post-nav { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; margin-top: 2.5rem; padding-top: 2rem; border-top: 1px solid var(--frost); }
.pn { background: var(--surface); border: 1px solid #dbe9ff; border-radius: 14px; padding: 1.1rem 1.3rem; text-decoration: none; color: inherit; transition: all .25s; display: flex; flex-direction: column; gap: .25rem; }
.pn:hover { border-color: var(--azure); transform: translateY(-2px); }
.pn-lbl { font-size: .73rem; font-weight: 800; text-transform: uppercase; letter-spacing: .1em; color: var(--cobalt); }
.pn-ttl { font-size: .88rem; font-weight: 600; color: var(--tx-dark); line-height: 1.45; }
.pn-next { text-align: right; align-items: flex-end; }

@media (max-width: 900px) {
  .single-grid { grid-template-columns: 1fr; }
  .related-grid { grid-template-columns: 1fr 1fr; }
  .post-nav { grid-template-columns: 1fr; }
  .single-meta-bar { flex-direction: column; align-items: flex-start; }
  .sm-stats { gap: .8rem; }
}
@media (max-width: 600px) { .related-grid { grid-template-columns: 1fr; } }

/* ─── SIDEBAR ─── */
.single-side { display: flex; flex-direction: column; gap: 1.2rem; position: sticky; top: 90px; }
.toc-card { background: var(--surface); border: 1px solid #dbe9ff; border-radius: 16px; padding: 1.3rem; }
.toc-h { font-family: 'Cormorant Garamond', serif; font-size: 1.05rem; font-weight: 700; color: var(--tx-dark); margin-bottom: .9rem; }
.toc-list { list-style: decimal inside; padding: 0; margin: 0; }
.toc-list li { font-size: .83rem; color: var(--tx-mid); line-height: 1.6; margin-bottom: .5rem; padding: .35rem .55rem; border-radius: 7px; cursor: pointer; transition: all .2s; border-left: 2px solid transparent; }
.toc-list li:hover { background: var(--frost); color: var(--cobalt); border-left-color: var(--azure); }
.toc-list li.active { background: var(--frost); color: var(--cobalt); font-weight: 600; border-left-color: var(--cobalt); }
.toc-list .toc-empty { list-style: none; color: var(--tx-soft); font-style: italic; }

.side-cta { background: linear-gradient(135deg, var(--royal), var(--cobalt)); border-radius: 18px; padding: 1.8rem; color: #fff; text-align: center; }
.side-cta-ic { font-size: 2.5rem; margin-bottom: .8rem; }
.side-cta h4 { font-family: 'Cormorant Garamond', serif; font-size: 1.2rem; font-weight: 700; margin-bottom: .55rem; line-height: 1.3; }
.side-cta p { font-size: .85rem; color: rgba(255,255,255,.7); margin-bottom: 1.2rem; line-height: 1.55; }
.side-cta .btn-primary { background: linear-gradient(135deg, var(--gold-lt), var(--gold)); color: var(--ink); width: 100%; justify-content: center; }

@media (max-width: 900px) { .single-side { position: static; } }

/* ═══════════════════════════════════════════════════════════
   PROGRAM STUDI SINGLE — 8-Panel layout
═══════════════════════════════════════════════════════════ */
.prodi-single { background: var(--surface); }

.prodi-hero { position: relative; overflow: hidden; background: var(--ink); padding: clamp(5.5rem, 10vw, 9rem) 0 clamp(3rem, 5vw, 4.5rem); }
.prodi-hero::before { content: ''; position: absolute; inset: 0; background: radial-gradient(ellipse 60% 50% at 70% 25%, rgba(12,61,122,.5) 0%, transparent 65%); }
.ph-grid { position: relative; z-index: 2; display: grid; grid-template-columns: 1.3fr 1fr; gap: clamp(2.5rem, 5vw, 4.5rem); align-items: center; }
.ph-h1 { font-family: 'Cormorant Garamond', serif; font-size: clamp(2.4rem, 4.5vw, 3.8rem); color: #fff; font-weight: 700; line-height: 1.12; margin: .9rem 0 1rem; }
.ph-meta { display: flex; flex-wrap: wrap; gap: 1.1rem; color: rgba(255,255,255,.7); font-size: .88rem; font-weight: 500; }
.ph-lead { color: rgba(255,255,255,.7); font-size: 1.02rem; line-height: 1.78; max-width: 580px; margin: 1.5rem 0 2rem; }
.ph-stats { display: grid; grid-template-columns: repeat(4, 1fr); gap: .9rem; }
.ph-stat { background: rgba(255,255,255,.04); border: 1px solid rgba(255,255,255,.08); border-radius: 13px; padding: 1rem 1.1rem; }
.ph-num { font-family: 'Cormorant Garamond', serif; font-size: 1.7rem; color: var(--cerulean); font-weight: 700; line-height: 1; }
.ph-lbl { font-size: .73rem; color: rgba(255,255,255,.5); margin-top: .3rem; }
.ph-cta { display: flex; gap: .8rem; flex-wrap: wrap; margin-top: 2rem; }
.ph-feat { border-radius: 22px; overflow: hidden; box-shadow: 0 24px 60px rgba(0,0,0,.4); aspect-ratio: 4/3; background: linear-gradient(135deg, var(--royal), var(--cobalt)); display: flex; align-items: center; justify-content: center; }
.ph-feat img { width: 100%; height: 100%; object-fit: cover; }
.ph-feat-fallback { font-size: 6rem; opacity: .8; }

@media (max-width: 1024px) { .ph-grid { grid-template-columns: 1fr; } .ph-stats { grid-template-columns: repeat(2, 1fr); } }

.prodi-tab-wrap-8 { display: flex; gap: .35rem; padding: .4rem; background: #fff; border: 1px solid #dbe9ff; border-radius: 14px; width: fit-content; max-width: 100%; overflow-x: auto; margin: 0 auto 2.5rem; }
.ptab-8 { padding: .55rem 1.15rem; border-radius: 10px; font-size: .8rem; font-weight: 700; color: var(--tx-mid); background: transparent; cursor: pointer; transition: all .22s; white-space: nowrap; border: 0; font-family: inherit; }
.ptab-8.on { background: var(--cobalt); color: #fff; box-shadow: 0 4px 14px rgba(20,89,179,.32); }
.ptab-8:hover:not(.on) { background: var(--frost); color: var(--cobalt); }

.pp { display: none; }
.pp.on { display: block; animation: ppIn .35s var(--ease); }
@keyframes ppIn { from { opacity: 0; transform: translateY(8px); } to { opacity: 1; transform: none; } }

.pp-h2 { font-family: 'Cormorant Garamond', serif; font-size: clamp(1.8rem, 3vw, 2.4rem); color: var(--tx-dark); font-weight: 700; line-height: 1.2; margin: 0 0 1.5rem; }
.pp-content { font-size: 1rem; line-height: 1.85; color: var(--tx-body); }
.pp-content p { margin-bottom: 1.1rem; }
.pp-content h3 { font-family: 'Cormorant Garamond', serif; color: var(--tx-dark); font-size: 1.3rem; margin: 1.8rem 0 .8rem; }

.pp-grid { display: grid; grid-template-columns: 1.6fr 1fr; gap: 2.5rem; align-items: start; }
.pp-info-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; margin-top: 2rem; }
.pp-info { background: var(--surface); border: 1px solid #dbe9ff; border-radius: 13px; padding: 1.1rem 1.2rem; }
.pi-lbl { display: block; font-size: .73rem; font-weight: 800; letter-spacing: .1em; text-transform: uppercase; color: var(--tx-soft); margin-bottom: .35rem; }
.pi-val { display: block; font-family: 'Cormorant Garamond', serif; font-size: 1.2rem; font-weight: 700; color: var(--cobalt); }

.pp-side-card { background: linear-gradient(155deg, var(--royal) 0%, var(--deep) 60%, var(--cobalt) 100%); border-radius: 18px; padding: 1.8rem; color: #fff; position: sticky; top: 90px; }
.psc-h { font-family: 'Cormorant Garamond', serif; font-size: 1.15rem; font-weight: 700; margin-bottom: 1rem; }
.psc-list { list-style: none; padding: 0; margin: 0 0 1.5rem; }
.psc-list li { padding: .55rem 0; border-bottom: 1px solid rgba(255,255,255,.1); font-size: .88rem; color: rgba(255,255,255,.85); }
.psc-list li:last-child { border-bottom: 0; }
.pp-side-cta { width: 100%; justify-content: center; background: linear-gradient(135deg, var(--gold-lt), var(--gold)); color: var(--ink); }

/* Visi Misi card */
.vm-card { background: #fff; border: 1px solid #dbe9ff; border-radius: 18px; padding: clamp(1.5rem, 3vw, 2.2rem); margin-bottom: 1.5rem; }
.vm-badge { display: inline-block; background: linear-gradient(135deg, var(--azure), var(--royal)); color: #fff; padding: .3rem .9rem; border-radius: 7px; font-size: .75rem; font-weight: 800; letter-spacing: .08em; margin-bottom: 1.1rem; }
.vm-visi { font-family: 'Cormorant Garamond', serif; font-size: clamp(1.2rem, 1.8vw, 1.5rem); font-style: italic; color: var(--tx-dark); line-height: 1.55; padding-left: 1.3rem; border-left: 3px solid var(--azure); }
.vm-misi { padding-left: 1.5rem; }
.vm-misi li { font-size: 1rem; color: var(--tx-body); line-height: 1.7; margin-bottom: .8rem; }

/* Tujuan & Kompetensi */
.tk-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 1.2rem; }
.tk-card { background: #fff; border: 1px solid #dbe9ff; border-radius: 16px; padding: 1.7rem; transition: all .25s; }
.tk-card:hover { border-color: var(--azure); box-shadow: 0 12px 30px rgba(12,61,122,.1); transform: translateY(-3px); }
.tk-ic { font-size: 2rem; margin-bottom: .8rem; }
.tk-card h4 { font-family: 'Cormorant Garamond', serif; font-size: 1.15rem; font-weight: 700; color: var(--tx-dark); margin-bottom: .5rem; }
.tk-card p { font-size: .88rem; color: var(--tx-mid); line-height: 1.6; }

/* Profil Lulusan */
.pl-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.2rem; }
.pl-card { background: var(--surface); border: 1px solid #dbe9ff; border-radius: 16px; padding: 1.5rem; transition: all .25s; }
.pl-card:hover { border-color: var(--azure); background: #fff; transform: translateY(-3px); box-shadow: 0 12px 30px rgba(12,61,122,.1); }
.pl-ic { font-size: 2rem; margin-bottom: .7rem; }
.pl-card h4 { font-family: 'Cormorant Garamond', serif; font-size: 1.05rem; font-weight: 700; color: var(--tx-dark); margin-bottom: .45rem; }
.pl-card p { font-size: .85rem; color: var(--tx-mid); line-height: 1.55; }

/* Struktur Organisasi */
.so-tree { display: flex; flex-direction: column; align-items: center; }
.so-node { background: #fff; border: 1.5px solid #dbe9ff; border-radius: 14px; padding: 1.1rem 1.5rem; display: flex; align-items: center; gap: 1rem; min-width: 260px; box-shadow: 0 6px 18px rgba(12,61,122,.07); }
.so-root { background: linear-gradient(135deg, var(--royal), var(--cobalt)); color: #fff; border-color: transparent; }
.so-root .so-name { color: #fff; }
.so-root .so-role { color: rgba(255,255,255,.65); }
.so-avatar { font-size: 2rem; }
.so-name { font-family: 'Cormorant Garamond', serif; font-size: 1.05rem; font-weight: 700; color: var(--tx-dark); }
.so-role { font-size: .75rem; color: var(--tx-soft); margin-top: .15rem; }
.so-line { width: 2px; height: 28px; background: var(--frost); margin: 0 auto; }
.so-row { display: flex; gap: 1.2rem; flex-wrap: wrap; justify-content: center; }
.so-row .so-node { flex-direction: column; text-align: center; min-width: 200px; gap: .5rem; padding: 1rem 1.2rem; }
.so-leaf { background: var(--surface); }
@media (max-width: 700px) { .so-row { flex-direction: column; align-items: stretch; } .so-row .so-node { flex-direction: row; text-align: left; } }

/* Dosen */
.dosen-head { display: flex; align-items: center; justify-content: space-between; gap: 1.5rem; flex-wrap: wrap; margin-bottom: 2rem; }
.dosen-filters { display: flex; gap: .5rem; flex-wrap: wrap; }
.dosen-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1.2rem; }
.dosen-card { background: #fff; border: 1px solid #dbe9ff; border-radius: 16px; padding: 1.5rem 1.2rem; text-align: center; transition: all .25s; }
.dosen-card.hide { display: none; }
.dosen-card:hover { border-color: var(--azure); box-shadow: 0 12px 30px rgba(12,61,122,.1); transform: translateY(-3px); }
.dosen-avatar { font-size: 2.8rem; margin-bottom: .8rem; }
.dosen-name { font-family: 'Cormorant Garamond', serif; font-size: .98rem; font-weight: 700; color: var(--tx-dark); line-height: 1.35; margin-bottom: .35rem; }
.dosen-jab { display: inline-block; background: var(--frost); color: var(--royal); padding: .2rem .65rem; border-radius: 6px; font-size: .68rem; font-weight: 700; margin-bottom: .45rem; }
.dosen-bid { display: block; font-size: .73rem; color: var(--tx-soft); }

@media (max-width: 900px) { .dosen-grid { grid-template-columns: repeat(2, 1fr); } .pl-grid { grid-template-columns: 1fr 1fr; } .tk-grid { grid-template-columns: 1fr; } }
@media (max-width: 600px) { .dosen-grid { grid-template-columns: 1fr 1fr; } .pl-grid { grid-template-columns: 1fr; } }

/* Mata Kuliah */
.mk-tab-wrap { display: flex; gap: .35rem; padding: .3rem; background: var(--surface); border: 1px solid #dbe9ff; border-radius: 11px; width: fit-content; margin-bottom: 1.5rem; }
.mk-tab { padding: .5rem 1.1rem; border-radius: 8px; font-size: .8rem; font-weight: 700; color: var(--tx-mid); background: transparent; cursor: pointer; transition: all .22s; border: 0; font-family: inherit; }
.mk-tab.on { background: #fff; color: var(--royal); box-shadow: 0 2px 10px rgba(0,0,0,.08); }
.mk-pane { display: none; }
.mk-pane.on { display: block; }
.mk-table { width: 100%; border-collapse: collapse; background: #fff; border: 1px solid #dbe9ff; border-radius: 14px; overflow: hidden; }
.mk-table th { background: var(--surface); font-family: 'Cormorant Garamond', serif; font-size: .82rem; font-weight: 800; letter-spacing: .08em; text-transform: uppercase; color: var(--tx-mid); padding: 1rem 1.2rem; text-align: left; border-bottom: 1px solid #dbe9ff; }
.mk-table th.mk-sks { text-align: center; }
.mk-table td { padding: 1.1rem 1.2rem; border-bottom: 1px solid #f0f6ff; font-size: .92rem; }
.mk-table tr:last-child td { border-bottom: 0; }
.mk-table tr:hover td { background: var(--frost); }
.mk-kode { font-family: 'Courier New', monospace; background: var(--frost); color: var(--royal); padding: .25rem .55rem; border-radius: 5px; font-size: .78rem; font-weight: 700; }
.mk-nama { font-weight: 600; color: var(--tx-dark); }
.mk-sks-val { text-align: center; font-weight: 700; color: var(--cobalt); }
.mk-act { text-align: center; }
.mk-dot { display: inline-block; width: 8px; height: 8px; border-radius: 50%; background: var(--cobalt); }
.mk-total td { background: var(--surface); font-weight: 800; color: var(--tx-dark); font-size: .92rem; }
.mk-total td:first-child { font-family: 'Cormorant Garamond', serif; font-size: 1rem; }
@media (max-width: 600px) { .mk-table th, .mk-table td { padding: .8rem .7rem; font-size: .82rem; } }

/* ═══════════════════════════════════════════════════════════
   TOAST / Tooltip (success messages)
═══════════════════════════════════════════════════════════ */
.itsi-toast { position: fixed; bottom: 2rem; left: 50%; transform: translateX(-50%) translateY(100px); background: var(--ink); border: 1px solid var(--gb); color: #fff; padding: 1rem 1.5rem; border-radius: 13px; font-size: .88rem; font-weight: 500; z-index: 9999; opacity: 0; transition: all .35s var(--ease); box-shadow: 0 18px 50px rgba(0,0,0,.5); }
.itsi-toast.show { opacity: 1; transform: translateX(-50%) translateY(0); }
.itsi-toast.success { background: linear-gradient(135deg, #1f6f3a, #2d8a4f); border-color: #2d8a4f; }
.itsi-toast.error { background: linear-gradient(135deg, #8a2d2d, #c0392b); border-color: #c0392b; }

/* ═══════════════════════════════════════════════════════════
   INFO PUBLIK ARCHIVE — page hero, stats, table, KIP, form
═══════════════════════════════════════════════════════════ */

/* Page hero */
#phero { position:relative; overflow:hidden; background:var(--ink); padding:clamp(5.5rem,10vw,9rem) 0 clamp(3.5rem,6vw,5rem); }
.ph-bg { position:absolute; inset:0; background:radial-gradient(ellipse 65% 58% at 58% 30%,rgba(12,61,122,.48),transparent 62%),radial-gradient(ellipse 38% 45% at 6% 85%,rgba(8,39,79,.62),transparent 55%),linear-gradient(165deg,var(--ink),var(--navy)); }
.ph-dots { position:absolute; inset:0; opacity:.022; background-image:radial-gradient(circle,rgba(117,192,245,1) 1px,transparent 1px); background-size:44px 44px; }
.ph-blob { position:absolute; border-radius:50%; filter:blur(88px); pointer-events:none; }
.ph-b1 { width:460px; height:460px; background:radial-gradient(circle,rgba(20,89,179,.2),transparent 70%); top:-20%; right:-6%; animation:floatA 13s ease-in-out infinite; }
.ph-b2 { width:280px; height:280px; background:radial-gradient(circle,rgba(8,39,79,.28),transparent 70%); bottom:-8%; left:0; animation:floatB 10s ease-in-out infinite; }
.ph-inner { position:relative; z-index:2; }
.bc { display:flex; align-items:center; gap:.45rem; font-size:.72rem; color:rgba(255,255,255,.35); margin-bottom:1.2rem; flex-wrap:wrap; }
.bc a { transition:color .2s; } .bc a:hover { color:rgba(255,255,255,.8); }
.ph-title { font-family:'Cormorant Garamond',serif; font-size:clamp(2.4rem,4.5vw,3.8rem); font-weight:700; color:#fff; line-height:1.08; margin-bottom:.65rem; }
.ph-title em { font-style:italic; color:var(--gold-lt); }
.ph-sub { font-size:.95rem; color:rgba(255,255,255,.5); line-height:1.8; max-width:580px; }

/* Stats bar */
#statsbar { background:linear-gradient(135deg,var(--navy),var(--deep)); border-bottom:1px solid rgba(255,255,255,.07); }
.sb-inner { display:grid; grid-template-columns:repeat(4,1fr); }
.sb-item { padding:1.5rem 1.2rem; text-align:center; border-right:1px solid rgba(255,255,255,.07); transition:background .2s; }
.sb-item:last-child { border-right:none; }
.sb-item:hover { background:rgba(255,255,255,.03); }
.sb-n { font-family:'Cormorant Garamond',serif; font-size:1.85rem; font-weight:700; color:var(--gold-lt); line-height:1; }
.sb-l { font-size:.67rem; font-weight:600; color:rgba(255,255,255,.42); margin-top:.25rem; }

/* Main wrap */
.main-wrap { padding:clamp(2.5rem,4.5vw,4.5rem) 0; }

/* PPID Banner */
.ppid-banner { background:linear-gradient(135deg,var(--deep),var(--royal)); border-radius:22px; padding:2rem 2.2rem; margin-bottom:2.5rem; display:flex; align-items:center; gap:2rem; flex-wrap:wrap; }
.ppid-ic { font-size:2.8rem; flex-shrink:0; }
.ppid-title { font-family:'Cormorant Garamond',serif; font-size:1.35rem; font-weight:700; color:#fff; margin-bottom:.4rem; }
.ppid-desc { font-size:.88rem; color:rgba(255,255,255,.55); line-height:1.7; max-width:500px; margin:0; }
.ppid-btns { display:flex; gap:.65rem; flex-wrap:wrap; margin-left:auto; }
.ppid-btn { display:inline-flex; align-items:center; gap:.45rem; padding:.65rem 1.35rem; border-radius:10px; font-size:.83rem; font-weight:700; transition:all .25s; white-space:nowrap; text-decoration:none; }
.ppid-btn-main { background:#fff; color:var(--royal); box-shadow:0 4px 16px rgba(0,0,0,.2); }
.ppid-btn-main:hover { transform:translateY(-2px); box-shadow:0 8px 24px rgba(0,0,0,.3); }
.ppid-btn-out { border:1.5px solid rgba(255,255,255,.3); color:#fff; }
.ppid-btn-out:hover { background:rgba(255,255,255,.12); }

/* Toolbar */
.toolbar { display:flex; align-items:center; gap:1rem; margin-bottom:1.5rem; flex-wrap:wrap; }
.search-wrap { display:flex; align-items:center; gap:.6rem; background:var(--white); border:1.5px solid #C8DEFF; border-radius:11px; padding:.62rem .95rem; flex:1; max-width:360px; transition:border-color .2s; }
.search-wrap:focus-within { border-color:var(--azure); box-shadow:0 0 0 3px rgba(30,114,212,.1); }
.search-wrap input { border:none; background:transparent; font-family:inherit; font-size:.85rem; color:var(--tx-body); width:100%; outline:none; }
.search-wrap input::placeholder { color:var(--tx-soft); }
.kat-filter { display:flex; gap:.4rem; flex-wrap:wrap; flex:1; }
.kf-btn { padding:.4rem .9rem; border-radius:30px; font-size:.76rem; font-weight:700; background:var(--white); border:1.5px solid #C8DEFF; color:var(--tx-mid); cursor:pointer; transition:all .2s; white-space:nowrap; }
.kf-btn.on { background:var(--cobalt); border-color:var(--cobalt); color:#fff; }
.kf-btn:hover:not(.on) { border-color:var(--azure); color:var(--cobalt); }

/* Document table */
.doc-table-wrap { background:var(--white); border:1px solid #C8DEFF; border-radius:20px; overflow:hidden; box-shadow:0 4px 20px rgba(0,0,0,.04); }
.doc-count { font-size:.84rem; color:var(--tx-soft); padding:.85rem 1.3rem; border-bottom:1px solid var(--surface); }
.doc-count strong { color:var(--tx-dark); }
.doc-tbl { width:100%; border-collapse:collapse; }
.doc-tbl thead th { background:linear-gradient(135deg,var(--navy),var(--deep)); color:rgba(255,255,255,.7); font-size:.72rem; font-weight:700; padding:.8rem 1.1rem; text-align:left; white-space:nowrap; }
.doc-tbl thead th:first-child { width:44px; text-align:center; }
.doc-tbl tbody tr { border-bottom:1px solid var(--surface); transition:background .15s; }
.doc-tbl tbody tr:last-child { border-bottom:none; }
.doc-tbl tbody tr:hover { background:var(--frost); }
.doc-no { font-weight:800; color:var(--cobalt); font-size:.75rem; text-align:center; width:44px; }
.doc-nm-wrap { display:flex; align-items:center; gap:.85rem; }
.doc-icon { font-size:1.3rem; flex-shrink:0; }
.doc-nm { font-size:.86rem; font-weight:700; color:var(--tx-dark); line-height:1.38; margin-bottom:.18rem; }
.doc-sub { font-size:.7rem; color:var(--tx-soft); }
.doc-kat-badge { font-size:.64rem; font-weight:700; text-transform:uppercase; letter-spacing:.05em; padding:.2rem .6rem; border-radius:6px; white-space:nowrap; display:inline-block; }
.doc-thn { font-size:.82rem; font-weight:600; color:var(--tx-mid); white-space:nowrap; }
.doc-dl-btn { display:inline-flex; align-items:center; gap:.4rem; padding:.38rem .88rem; border-radius:8px; font-size:.77rem; font-weight:700; background:var(--frost); color:var(--cobalt); border:1px solid var(--pale); transition:all .22s; white-space:nowrap; text-decoration:none; }
.doc-dl-btn:hover { background:var(--cobalt); color:#fff; border-color:var(--cobalt); }

/* KIP Info cards (archive) */
.kip-cards { display:grid; grid-template-columns:repeat(3,1fr); gap:1.1rem; margin-top:2.5rem; }
.kip-card { background:var(--white); border:1px solid #C8DEFF; border-radius:18px; padding:1.5rem; transition:all .28s var(--ease); }
.kip-card:hover { box-shadow:0 8px 28px rgba(12,61,122,.1); transform:translateY(-3px); border-color:#ADDAFF; }
.kip-ic { font-size:1.8rem; margin-bottom:.7rem; }
.kip-title { font-size:.9rem; font-weight:700; color:var(--tx-dark); margin-bottom:.45rem; }
.kip-text { font-size:.83rem; color:var(--tx-mid); line-height:1.68; margin:0; }

/* Permohonan form (archive) */
.form-section { background:var(--white); border:1px solid #C8DEFF; border-radius:22px; padding:2rem; margin-top:2.5rem; }
.form-title { font-family:'Cormorant Garamond',serif; font-size:1.45rem; font-weight:700; color:var(--tx-dark); margin-bottom:.45rem; }
.form-title em { font-style:italic; color:var(--azure); }
.form-sub { font-size:.88rem; color:var(--tx-mid); line-height:1.7; margin-bottom:1.6rem; }
.form-grid { display:grid; grid-template-columns:1fr 1fr; gap:1.1rem; margin-bottom:1.1rem; }
.form-group { display:flex; flex-direction:column; gap:.42rem; }
.form-group.full { grid-column:1 / -1; }
.form-lbl { font-size:.78rem; font-weight:700; color:var(--tx-dark); }
.form-lbl span { color:#E53E3E; }
.form-inp { font-family:inherit; font-size:.86rem; color:var(--tx-body); background:var(--surface); border:1.5px solid #C8DEFF; border-radius:10px; padding:.68rem 1rem; width:100%; outline:none; transition:border-color .2s; }
.form-inp:focus { border-color:var(--azure); box-shadow:0 0 0 3px rgba(30,114,212,.1); background:var(--white); }
textarea.form-inp { resize:vertical; min-height:100px; }
select.form-inp { cursor:pointer; }
.form-submit { display:inline-flex; align-items:center; gap:.55rem; padding:.78rem 1.7rem; border-radius:12px; background:linear-gradient(135deg,var(--cobalt),var(--azure)); color:#fff; font-size:.88rem; font-weight:700; cursor:pointer; border:none; font-family:inherit; transition:all .28s; box-shadow:0 5px 20px rgba(20,89,179,.3); }
.form-submit:hover { transform:translateY(-2px); box-shadow:0 10px 28px rgba(20,89,179,.46); }

/* Toast */
.toast { position:fixed; bottom:5rem; right:1.8rem; z-index:1000; background:var(--deep); border:1px solid rgba(255,255,255,.12); color:#fff; font-size:.82rem; font-weight:600; padding:.7rem 1.3rem; border-radius:11px; box-shadow:0 8px 28px rgba(0,0,0,.4); transform:translateY(20px); opacity:0; transition:all .3s var(--ease); pointer-events:none; }
.toast.show { transform:translateY(0); opacity:1; }

/* Responsive */
@media(max-width:768px) {
  .form-grid { grid-template-columns:1fr; }
  .kip-cards { grid-template-columns:1fr; }
  .ppid-banner { flex-direction:column; align-items:flex-start; }
  .ppid-btns { margin-left:0; }
  .sb-inner { grid-template-columns:repeat(2,1fr); }
  .doc-tbl { font-size:.78rem; }
  .doc-tbl thead th, .doc-tbl tbody td { padding:.6rem .7rem; }
}
@media(max-width:580px) {
  .toolbar { flex-direction:column; align-items:stretch; }
  .search-wrap { max-width:100%; }
}


/* === Placeholder Image Styles (added by admin) === */
.placeholder-img {
  display: block;
  width: 100%;
  height: auto;
  border-radius: inherit;
  object-fit: cover;
}

/* pc-thumb: wraps each prodi card's placeholder */
.pc-thumb {
  position: relative;
  width: 100%;
  aspect-ratio: 16 / 8;
  border-radius: 12px;
  overflow: hidden;
  margin-bottom: .9rem;
}
.pc-thumb .placeholder-img {
  height: 100%;
  object-fit: cover;
}

/* nf-img is the featured berita image container */
.nfeat .nf-img {
  position: relative;
  overflow: hidden;
  aspect-ratio: 16/10;
}
.nfeat .nf-img .nf-img-photo {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  z-index: 0;
}
.nfeat .nf-img > *:not(.nf-img-photo) {
  position: relative;
  z-index: 1;
}

/* ns-card small thumbnails */
.ns-card .ns-img {
  position: relative;
  overflow: hidden;
}
.ns-card .ns-img .placeholder-img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.ns-card .ns-img {
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 3rem;
  min-height: 80px;
}

/* art-img thumb */
.art-card .art-img {
  position: relative;
  overflow: hidden;
  min-height: 160px;
}
.art-card .art-img .placeholder-img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* ip-card thumb */
.ip-card .ip-card-img {
  border-radius: 8px;
  overflow: hidden;
  margin-bottom: .6rem;
}
.ip-card .placeholder-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* sam-avatar-img-wrap: opsi sampul rektor */
.sam-avatar-img-wrap {
  width: 110px;
  height: 110px;
  border-radius: 50%;
  margin: 0 auto 14px;
  overflow: hidden;
  border: 4px solid #fff;
  box-shadow: 0 12px 28px rgba(10,58,126,.16);
}
.sam-avatar-img-wrap img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}


/* === Sambutan avatar types (added 2026-06-29) === */
.sam-avatar-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 50%;
  display: block;
}
.sam-avatar-icon {
  font-size: 3rem;
  color: rgba(255,255,255,.92);
  line-height: 1;
}
.sam-avatar-emoji {
  font-size: 3rem;
  line-height: 1;
  display: inline-block;
}
