:root{
  --ink:#211d18; --ink-soft:#5c564c; --cream:#f1eadd; --cream-deep:#e7dcc8;
  --paper:#fbf7ef; --accent:#9a3b2e; --accent-deep:#7a2c22; --gold:#b8924a;
  --line:#ddd2bf; --shadow:rgba(40,30,15,.13);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:'Outfit',sans-serif;background:var(--paper);color:var(--ink);line-height:1.7;overflow-x:hidden;-webkit-font-smoothing:antialiased}
.serif{font-family:'Fraunces',serif}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.wrap{max-width:1200px;margin:0 auto;padding:0 32px}

/* grain */
body::before{content:"";position:fixed;inset:0;z-index:1;pointer-events:none;opacity:.04;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");}

/* NAV */
header.nav{position:fixed;top:0;left:0;right:0;z-index:50;display:flex;align-items:center;justify-content:space-between;padding:22px 40px;transition:.45s cubic-bezier(.2,.7,.2,1)}
header.nav.scrolled{background:rgba(251,247,239,.82);backdrop-filter:blur(14px) saturate(1.2);border-bottom:1px solid var(--line);padding:13px 40px;box-shadow:0 6px 40px var(--shadow)}
.brand{display:flex;align-items:center;gap:13px;font-family:'Fraunces',serif;font-weight:600;font-size:1.18rem;letter-spacing:.2px}
.brand .mark{width:38px;height:38px;border-radius:11px;background:var(--accent);color:var(--paper);display:grid;place-items:center;font-size:1.05rem;overflow:hidden;box-shadow:0 6px 18px rgba(154,59,46,.3)}
.brand .mark img{width:100%;height:100%;object-fit:cover}
nav.links{display:flex;gap:34px;font-size:.93rem;font-weight:400}
nav.links a{position:relative;padding:4px 0;color:var(--ink-soft);transition:.25s}
nav.links a:hover{color:var(--accent)}
nav.links a::after{content:"";position:absolute;left:0;bottom:-3px;width:0;height:1.5px;background:var(--accent);transition:.3s}
nav.links a:hover::after{width:100%}
.burger{display:none;flex-direction:column;gap:5px;cursor:pointer;z-index:60}
.burger span{width:26px;height:2px;background:var(--ink);transition:.3s}

/* HERO */
.hero{position:relative;padding:190px 0 110px;overflow:hidden}
.hero-bg{position:absolute;inset:0;z-index:0}
.hero-bg .blob{position:absolute;border-radius:50%;filter:blur(80px);opacity:.55}
.hero-bg .b1{width:560px;height:560px;background:radial-gradient(circle,var(--cream-deep),transparent 70%);top:-140px;right:-120px}
.hero-bg .b2{width:460px;height:460px;background:radial-gradient(circle,#dcb9ab,transparent 70%);bottom:-180px;left:-140px}
.hero-rule{position:absolute;left:40px;right:40px;top:160px;height:1px;background:linear-gradient(90deg,transparent,var(--line),transparent);opacity:.7}
.hero-grid{position:relative;z-index:2;display:grid;grid-template-columns:1.28fr .82fr;gap:70px;align-items:center}
.eyebrow{display:inline-flex;align-items:center;gap:12px;font-size:.76rem;letter-spacing:.32em;text-transform:uppercase;color:var(--accent);font-weight:600;margin-bottom:26px}
.eyebrow::before{content:"";width:42px;height:1px;background:var(--accent)}
.hero h1{font-family:'Fraunces',serif;font-weight:400;font-size:clamp(2.8rem,6.2vw,5rem);line-height:1.02;letter-spacing:-1.5px;margin-bottom:26px}
.hero h1 em{font-style:italic;color:var(--accent);font-weight:500}
.hero .sub{font-size:1.18rem;color:var(--ink-soft);max-width:34ch;margin-bottom:40px;font-weight:300}
.hero-cta{display:flex;gap:16px;flex-wrap:wrap}
.btn{display:inline-flex;align-items:center;gap:10px;padding:15px 32px;border-radius:40px;font-weight:500;font-size:.95rem;transition:.32s cubic-bezier(.2,.7,.2,1);cursor:pointer;border:none}
.btn-primary{background:var(--ink);color:var(--paper)}
.btn-primary:hover{background:var(--accent);transform:translateY(-3px);box-shadow:0 14px 34px rgba(154,59,46,.32)}
.btn-ghost{border:1px solid var(--line);color:var(--ink);background:transparent}
.btn-ghost:hover{border-color:var(--ink);transform:translateY(-3px)}
.hero-portrait{position:relative}
.hero-portrait .frame{position:relative;aspect-ratio:4/5;border-radius:220px 220px 26px 26px;overflow:hidden;background:var(--cream-deep);box-shadow:0 50px 90px var(--shadow);z-index:2}
.hero-portrait .frame img{width:100%;height:100%;object-fit:cover}
.hero-portrait .ph{width:100%;height:100%;display:grid;place-items:center;color:var(--line);font-family:'Fraunces',serif;font-size:6rem}
.hero-portrait .port-deco{position:absolute;inset:-18px -18px 30px 22px;border:1px solid var(--accent);border-radius:220px 220px 26px 26px;z-index:1;opacity:.4}
.hero-portrait .badge{position:absolute;bottom:30px;left:-30px;z-index:3;background:var(--paper);border:1px solid var(--line);padding:15px 22px;border-radius:18px;box-shadow:0 18px 44px var(--shadow);font-size:.82rem;color:var(--ink-soft)}
.hero-portrait .badge b{font-family:'Fraunces',serif;font-size:1.7rem;display:block;color:var(--accent);line-height:1}
.contact-strip{display:flex;gap:30px;margin-top:46px;flex-wrap:wrap;font-size:.9rem;color:var(--ink-soft)}
.contact-strip span{display:flex;align-items:center;gap:9px}
.contact-strip svg{width:16px;height:16px;stroke:var(--accent)}

/* SECTION */
section.block{padding:104px 0;position:relative;z-index:2}
.sec-head{margin-bottom:58px;max-width:720px}
.sec-head .kk{font-size:.76rem;letter-spacing:.3em;text-transform:uppercase;color:var(--gold);font-weight:600;margin-bottom:16px}
.sec-head h2{font-family:'Fraunces',serif;font-weight:400;font-size:clamp(2.1rem,4.2vw,3.1rem);line-height:1.07;letter-spacing:-.7px}
.sec-head p{color:var(--ink-soft);margin-top:16px;font-weight:300;font-size:1.06rem}
.sub-h{font-size:1.45rem;font-weight:500;margin-bottom:26px;color:var(--accent);letter-spacing:-.3px}
.alt{background:linear-gradient(180deg,var(--cream),var(--cream) 100%);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}

/* biografi */
.bio{display:grid;grid-template-columns:.8fr 1.2fr;gap:64px;align-items:center}
.bio-photo{aspect-ratio:1;border-radius:26px;overflow:hidden;background:var(--cream-deep);box-shadow:0 36px 70px var(--shadow)}
.bio-photo img{width:100%;height:100%;object-fit:cover}
.bio-photo .ph{height:100%;display:grid;place-items:center;color:var(--line);font-size:4.5rem;font-family:'Fraunces',serif}
.bio-text{font-size:1.12rem;color:var(--ink-soft);font-weight:300}
.bio-text .clamp-bio{display:-webkit-box;-webkit-line-clamp:5;-webkit-box-orient:vertical;overflow:hidden}
.bio-text p{margin-bottom:16px}
.bio-text strong{color:var(--ink);font-weight:600}
.read-more{display:inline-block;margin-top:18px;color:var(--accent);font-weight:600;font-size:.95rem;font-family:'Outfit';cursor:pointer;transition:.25s}
.read-more:hover{gap:10px;letter-spacing:.3px}

/* timeline */
.timeline{position:relative;padding-left:36px}
.timeline::before{content:"";position:absolute;left:9px;top:6px;bottom:6px;width:2px;background:linear-gradient(var(--accent),var(--gold))}
.tl-item{position:relative;padding-bottom:42px}
.tl-item:last-child{padding-bottom:0}
.tl-item::before{content:"";position:absolute;left:-36px;top:4px;width:20px;height:20px;border-radius:50%;background:var(--paper);border:3px solid var(--accent)}
.tl-year{font-family:'Fraunces',serif;color:var(--accent);font-weight:600;font-size:1.05rem}
.tl-item h4{font-size:1.22rem;margin:3px 0 5px;font-weight:600}
.tl-item .meta{color:var(--ink-soft);font-size:.95rem}
.tl-item .desc{color:var(--ink-soft);font-size:.95rem;margin-top:8px;font-weight:300;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.tl-item .read-more{margin-top:8px;font-size:.86rem}

.two-col{display:grid;grid-template-columns:1fr 1fr;gap:70px}
@media(max-width:820px){.two-col{grid-template-columns:1fr;gap:56px}}

/* generic grids */
.cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(255px,1fr));gap:28px}
.card{background:var(--paper);border:1px solid var(--line);border-radius:20px;overflow:hidden;transition:.4s cubic-bezier(.2,.7,.2,1);display:flex;flex-direction:column;cursor:pointer}
.card:hover{transform:translateY(-8px);box-shadow:0 30px 56px var(--shadow);border-color:var(--accent)}
.card .cover{aspect-ratio:3/4;background:var(--cream-deep);overflow:hidden}
.card .cover img{width:100%;height:100%;object-fit:cover;transition:.5s}
.card:hover .cover img{transform:scale(1.05)}
.card .cover .ph{height:100%;display:grid;place-items:center;color:var(--line);font-size:2.6rem;font-family:'Fraunces',serif}
.card .body{padding:22px;flex:1;display:flex;flex-direction:column;gap:9px}
.card .tag{font-size:.71rem;letter-spacing:.14em;text-transform:uppercase;color:var(--gold);font-weight:600}
.card h4{font-family:'Fraunces',serif;font-size:1.15rem;font-weight:500;line-height:1.22}
.card .yr{font-size:.85rem;color:var(--ink-soft)}
.card .syn{font-size:.9rem;color:var(--ink-soft);font-weight:300;flex:1;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.card .lnk{font-size:.85rem;color:var(--accent);font-weight:600;margin-top:6px}

/* teach/train cards */
.teach-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:24px}
.teach{padding:30px;border:1px solid var(--line);border-radius:20px;background:var(--paper);transition:.35s cubic-bezier(.2,.7,.2,1);position:relative;overflow:hidden;cursor:pointer}
.teach:hover{border-color:var(--accent);transform:translateY(-5px);box-shadow:0 24px 46px var(--shadow)}
.teach .lvl{display:inline-block;font-size:.71rem;font-weight:700;letter-spacing:.12em;color:var(--paper);background:var(--accent);padding:5px 13px;border-radius:20px;margin-bottom:16px}
.teach h4{font-family:'Fraunces',serif;font-size:1.32rem;font-weight:500;margin-bottom:9px}
.teach .desc{color:var(--ink-soft);font-size:.94rem;font-weight:300;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.teach .read-more{margin-top:12px;font-size:.86rem}

/* pkm */
.pkm-list{display:flex;flex-direction:column;gap:26px}
.pkm{display:grid;grid-template-columns:120px 1fr;gap:28px;padding:28px;border:1px solid var(--line);border-radius:20px;background:var(--paper);transition:.35s;align-items:start}
.pkm:hover{box-shadow:0 24px 46px var(--shadow);border-color:var(--gold)}
.pkm .date-box{text-align:center;border-right:1px solid var(--line);padding-right:22px}
.pkm .date-box .d{font-family:'Fraunces',serif;font-size:2.5rem;font-weight:600;color:var(--accent);line-height:1}
.pkm .date-box .my{font-size:.82rem;color:var(--ink-soft);text-transform:uppercase;letter-spacing:.1em;margin-top:5px}
.pkm h4{font-family:'Fraunces',serif;font-size:1.32rem;font-weight:500;margin-bottom:7px}
.pkm .tags{display:flex;gap:10px;flex-wrap:wrap;margin:9px 0;font-size:.8rem}
.pkm .tags span{background:var(--cream-deep);padding:5px 13px;border-radius:20px;color:var(--ink-soft)}
.pkm .desc{color:var(--ink-soft);font-size:.95rem;font-weight:300;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.pkm .gallery{display:flex;gap:8px;margin-top:14px;flex-wrap:wrap}
.pkm .gallery img{width:66px;height:66px;object-fit:cover;border-radius:9px;border:1px solid var(--line)}
.pkm .read-more{margin-top:10px;font-size:.86rem}

/* opini grid */
.opini-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(310px,1fr));gap:28px}
.opini{border:1px solid var(--line);border-radius:20px;overflow:hidden;background:var(--paper);transition:.35s cubic-bezier(.2,.7,.2,1);display:flex;flex-direction:column;cursor:pointer}
.opini:hover{transform:translateY(-6px);box-shadow:0 26px 50px var(--shadow);border-color:var(--accent)}
.opini .img{aspect-ratio:16/9;background:var(--cream-deep);overflow:hidden}
.opini .img img{width:100%;height:100%;object-fit:cover}
.opini .img .ph{height:100%;display:grid;place-items:center;color:var(--line);font-size:2.2rem;font-family:'Fraunces',serif}
.opini .b{padding:24px}
.opini h4{font-family:'Fraunces',serif;font-size:1.28rem;font-weight:500;margin-bottom:11px;line-height:1.2}
.opini .ex{color:var(--ink-soft);font-size:.95rem;font-weight:300;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}

/* mitra */
.mitra-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:22px}
.mitra-card{display:flex;align-items:center;gap:16px;padding:22px 24px;border:1px solid var(--line);border-radius:18px;background:var(--paper);transition:.3s}
.mitra-card:hover{border-color:var(--gold);box-shadow:0 18px 38px var(--shadow);transform:translateY(-4px)}
.mitra-card .logo{width:54px;height:54px;border-radius:13px;background:var(--cream-deep);display:grid;place-items:center;font-family:'Fraunces',serif;font-size:1.4rem;color:var(--accent);overflow:hidden;flex-shrink:0}
.mitra-card .logo img{width:100%;height:100%;object-fit:cover}
.mitra-card .mn{font-weight:600;font-size:1rem;line-height:1.25}
.mitra-card .mk{font-size:.8rem;color:var(--ink-soft)}

/* ====== CAROUSEL ====== */
.carousel{position:relative}
.carousel-track{display:flex;gap:24px;overflow-x:auto;scroll-snap-type:x mandatory;scroll-behavior:smooth;padding:6px 2px 18px;-ms-overflow-style:none;scrollbar-width:none}
.carousel-track::-webkit-scrollbar{display:none}
.carousel-track > *{scroll-snap-align:start;flex:0 0 auto}
.carousel.c-cards .carousel-track > *{width:265px}
.carousel.c-wide .carousel-track > *{width:320px}
.carousel.c-mitra .carousel-track > *{width:270px}
.carousel-nav{position:absolute;top:-66px;right:0;display:flex;gap:10px}
.cbtn{width:46px;height:46px;border-radius:50%;border:1px solid var(--line);background:var(--paper);color:var(--ink);display:grid;place-items:center;cursor:pointer;transition:.25s;font-size:1.1rem}
.cbtn:hover{background:var(--ink);color:var(--paper);border-color:var(--ink)}
.cbtn:disabled{opacity:.3;cursor:default}
.cbtn:disabled:hover{background:var(--paper);color:var(--ink);border-color:var(--line)}
.carousel-dots{display:flex;gap:7px;justify-content:center;margin-top:18px}
.cdot{width:7px;height:7px;border-radius:50%;background:var(--line);transition:.3s;cursor:pointer}
.cdot.on{background:var(--accent);width:22px;border-radius:4px}

/* ====== DETAIL VIEW ====== */
.detail-view{display:none;position:relative;z-index:3;min-height:100vh;background:var(--paper);animation:fadeDt .5s}
body.is-detail #detailView{display:block}
body.is-detail main > section.block,
body.is-detail main > .hero,
body.is-detail > footer,
body.is-detail > header.nav{display:none!important}
@keyframes fadeDt{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}
.detail-top{position:sticky;top:0;z-index:10;background:rgba(251,247,239,.85);backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
.dt-bar{display:flex;align-items:center;justify-content:space-between;padding-top:20px;padding-bottom:20px}
.dt-back{font-weight:500;color:var(--ink);transition:.25s}
.dt-back:hover{color:var(--accent)}
.dt-brand{font-size:1.1rem;font-weight:600}
.detail-article{max-width:760px;padding-top:70px;padding-bottom:120px}
.detail-article .dt-kk{font-size:.76rem;letter-spacing:.3em;text-transform:uppercase;color:var(--gold);font-weight:600;margin-bottom:20px}
.detail-article h1{font-family:'Fraunces',serif;font-weight:400;font-size:clamp(2.1rem,5vw,3.3rem);line-height:1.1;letter-spacing:-1px;margin-bottom:22px}
.detail-article .dt-meta{display:flex;gap:18px;flex-wrap:wrap;color:var(--ink-soft);font-size:.92rem;margin-bottom:34px;padding-bottom:28px;border-bottom:1px solid var(--line)}
.detail-article .dt-meta b{color:var(--accent);font-weight:600}
.detail-article .dt-cover{border-radius:20px;overflow:hidden;margin-bottom:38px;max-height:440px;background:var(--cream-deep)}
.detail-article .dt-cover img{width:100%;height:100%;object-fit:cover}
.detail-body{font-size:1.18rem;line-height:1.9;color:#322d26;font-weight:300}
.detail-body p{margin-bottom:22px}
.detail-body h3{font-family:'Fraunces',serif;font-size:1.5rem;font-weight:500;margin:34px 0 14px}
.detail-body strong{color:var(--ink);font-weight:600}
.detail-body a{color:var(--accent);text-decoration:underline}
.detail-body ul,.detail-body ol{margin:0 0 22px 22px}
.detail-body img{border-radius:14px;margin:24px 0}
.dt-gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:14px;margin-top:30px}
.dt-gallery img{width:100%;aspect-ratio:1;object-fit:cover;border-radius:14px;border:1px solid var(--line)}
.dt-extlink{display:inline-flex;margin-top:30px;padding:13px 26px;border-radius:40px;background:var(--ink);color:var(--paper);font-weight:500;font-size:.92rem;transition:.3s}
.dt-extlink:hover{background:var(--accent)}

/* ====== FLOATING ACTION BUTTONS ====== */
.fab-stack{position:fixed;right:26px;bottom:26px;z-index:60;display:flex;flex-direction:column;gap:12px;align-items:flex-end}
body.is-detail .fab-stack{display:none!important}
.fab{padding:13px 24px;border-radius:40px;font-weight:600;font-size:.9rem;box-shadow:0 14px 36px rgba(40,30,15,.26);transition:.3s cubic-bezier(.2,.7,.2,1);display:inline-flex;align-items:center;gap:8px;cursor:pointer}
.fab-site{background:var(--paper);color:var(--ink);border:1px solid var(--line)}
.fab-site:hover{transform:translateY(-3px) scale(1.03)}
.fab-admin{background:var(--accent);color:#fff}
.fab-admin:hover{background:var(--accent-deep);transform:translateY(-3px) scale(1.03)}

/* footer */
footer{background:var(--ink);color:var(--cream);padding:80px 0 38px;position:relative;z-index:2}
.foot-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr;gap:44px;margin-bottom:52px}
footer h3{font-family:'Fraunces',serif;font-size:1.9rem;font-weight:500;margin-bottom:16px}
footer p{color:#bdb4a4;font-weight:300}
footer .fcol h5{font-size:.76rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin-bottom:18px}
footer .fcol a{display:block;color:#cfc6b6;margin-bottom:11px;font-size:.95rem;transition:.25s}
footer .fcol a:hover{color:var(--paper);padding-left:5px}
.foot-bottom{border-top:1px solid #38332b;padding-top:26px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;color:#8c8475;font-size:.85rem}

.reveal{opacity:0;transform:translateY(30px);transition:.85s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}

@media(max-width:920px){
  .hero-grid{grid-template-columns:1fr;gap:54px}
  .hero-portrait{max-width:400px}
  .bio{grid-template-columns:1fr;gap:40px}
}
@media(max-width:760px){
  header.nav{padding:16px 24px}
  nav.links{position:fixed;inset:0 0 0 auto;width:76%;max-width:330px;background:var(--paper);flex-direction:column;padding:96px 36px;gap:24px;transform:translateX(100%);transition:.42s cubic-bezier(.2,.7,.2,1);box-shadow:-24px 0 70px var(--shadow);z-index:40}
  nav.links.open{transform:none}
  .burger{display:flex}
  .pkm{grid-template-columns:1fr}
  .pkm .date-box{border-right:none;border-bottom:1px solid var(--line);padding:0 0 14px;display:flex;gap:12px;align-items:baseline}
  .foot-grid{grid-template-columns:1fr}
  .fab-stack{right:16px;bottom:16px}
}
