/* ==========================================================================
   Kisima UI v2
   Part 1 — Foundation
   Matches the uploaded templates
   ========================================================================== */
/* ==========================================================================
   Design Tokens
   ========================================================================== */
:root {
    /* Brand */
    --kr-orange: #ff6b00;
    --kr-orange-dark: #d95b00;
    --kr-black: #0f1115;
    --kr-bg: #f6f8fb;
    --kr-surface: #ffffff;
    --kr-surface-2: #f1f4f8;
    --kr-text: #23272f;
    --kr-text-light: #6d7785;
    --kr-border: rgba(15,17,21,.08);
    --kr-shadow-sm: 0 8px 20px rgba(0,0,0,.05);
    --kr-shadow: 0 20px 60px rgba(0,0,0,.08);
    --kr-shadow-lg: 0 40px 100px rgba(0,0,0,.12);
    --kr-radius-sm: 12px;
    --kr-radius: 20px;
    --kr-radius-lg: 30px;
    --kr-speed: .25s;
    --header-height:92px;
}
/* ==========================================================================
   Reset
   ========================================================================== */
*,
*::before,
*::after{
    box-sizing:border-box;
}
html{
    scroll-behavior:smooth;
}
body{
    background:var(--kr-bg);
    color:var(--kr-text);
    font-family:"Plus Jakarta Sans",sans-serif;
    font-size:16px;
    line-height:1.7;
    overflow-x:hidden;
    text-rendering:optimizeLegibility;
    -webkit-font-smoothing:antialiased;
}
img{
    display:block;
    max-width:100%;
}
a{
    color:inherit;
    text-decoration:none;
    transition:all var(--kr-speed);
}
a:hover{
    text-decoration:none;
}
/* ==========================================================================
   Containers
   ========================================================================== */
.kr-container{
    width:min(1200px,calc(100% - 40px));
    margin-inline:auto;
}
.kr-container-wide{
    width:min(1380px,calc(100% - 48px));
    margin-inline:auto;
}
/* ==========================================================================
   Typography
   ========================================================================== */
.kr-eyebrow{
    display:inline-flex;
    align-items:center;
    gap:.6rem;
    color:var(--kr-orange);
    text-transform:uppercase;
    font-weight:800;
    letter-spacing:.18em;
    font-size:.78rem;
}
.kr-section-title{
    font-size:clamp(2.2rem,5vw,4rem);
    line-height:.95;
    font-weight:900;
    letter-spacing:-.05em;
    margin:0;
}
.kr-section-copy{
    color:var(--kr-text-light);
    max-width:620px;
    margin:0;
}
.kr-hero-title{
    font-size:clamp(3.2rem,7vw,6rem);
    line-height:.9;
    font-weight:900;
    letter-spacing:-.06em;
    color:#fff;
    margin-bottom:1.5rem;
    max-width:820px;
}
.kr-hero-subtitle{
    max-width:640px;
    color:rgba(255,255,255,.82);
    font-size:1.1rem;
}
.kr-hero-subtitle p{
    margin:0;
}
/* ==========================================================================
   Buttons
   ========================================================================== */
.kr-btn{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    gap:.7rem;
    padding:15px 24px;
    border-radius:999px;
    font-weight:700;
    transition:.25s;
}
.kr-btn-primary{
    background:var(--kr-orange);
    color:#fff;
    box-shadow:0 18px 45px rgba(255,107,0,.35);
}
.kr-btn-primary:hover{
    background:var(--kr-orange-dark);
    transform:translateY(-2px);
}
.kr-btn-outline{
    border:1px solid rgba(255,255,255,.25);
    color:#fff;
    backdrop-filter:blur(14px);
}
.kr-btn-outline:hover{
    background:rgba(255,255,255,.08);
}
/* ==========================================================================
   Cards
   ========================================================================== */
.kr-card{
    background:#fff;
    border-radius:24px;
    border:1px solid var(--kr-border);
    box-shadow:var(--kr-shadow);
    overflow:hidden;
    transition:.3s;
}
.kr-card:hover{
    transform:translateY(-6px);
    box-shadow:var(--kr-shadow-lg);
}
.kr-glass{
    background:rgba(255,255,255,.08);
    backdrop-filter:blur(20px);
    border:1px solid rgba(255,255,255,.14);
    border-radius:26px;
}
/* ===========================
   HEADER
=========================== */
.kr-site-header{
    position:fixed;
    top:0;
    left:0;
    right:0;
    z-index:1000;
    transition:.3s;
    padding-top:18px;
}
.kr-site-header.scrolled{
    backdrop-filter:blur(20px);
    background:rgba(15,17,21,.72);
    border-bottom:1px solid rgba(255,255,255,.08);
}
.kr-nav{
    display:grid;
    grid-template-columns:auto 1fr auto;
    align-items:center;
    gap:48px;
    height:88px;
    padding:0 28px;
    border-radius:22px;
    background:rgba(15,17,21,.55);
    backdrop-filter:blur(18px);
    border:1px solid rgba(255,255,255,.06);
}
.kr-logo img{
    height:80px;
}
.kr-nav-links{
    display:flex;
    justify-content:center;
    gap:42px;
    list-style:none;
    margin:0;
    padding:0;
}
.kr-nav-links a{
    color:#fff;
    font-weight:700;
    position:relative;
}
.kr-nav-links a::after{
    content:"";
    position:absolute;
    left:0;
    bottom:-8px;
    width:100%;
    height:2px;
    background:var(--kr-orange);
    transform:scaleX(0);
    transition:.25s;
}
.kr-nav-links a:hover::after{
    transform:scaleX(1);
}
.kr-menu-button{
    display:none;
    border:none;
    background:none;
    width:42px;
    cursor:pointer;
}
.kr-menu-button span{
    display:block;
    height:3px;
    margin:7px 0;
    background:#fff;
    border-radius:99px;
    transition:.3s;
}
.kr-mobile-menu{
    display:none;
}
@media(max-width:992px){
    .kr-nav-links{
        display:none;
    }
    .kr-nav-live{
        display:none;
    }
    .kr-menu-button{
        display:block;
    }
    .kr-mobile-menu{
        display:flex;
        flex-direction:column;
        background:#111;
        max-height:0;
        overflow:hidden;
        transition:.3s;
    }
    .kr-mobile-menu.open{
        max-height:500px;
        padding:20px;
    }
    .kr-mobile-menu a{
        color:#fff;
        padding:14px 0;
        border-bottom:1px solid rgba(255,255,255,.08);
    }
}
/* ==========================================================================
   Hero
   ========================================================================== */
.kr-hero{
    position:relative;
    padding-top:130px;
    padding-bottom:90px;
    overflow:hidden;
    background:
    radial-gradient(circle at 85% 15%,rgba(255,107,0,.18),transparent 28%),
    linear-gradient(135deg,#0d0d0d,#171717);
}
.kr-hero::before{
    content:"";
    position:absolute;
    inset:0;
    background:linear-gradient(90deg,
    rgba(0,0,0,.85),
    rgba(0,0,0,.55));
}
.kr-hero>*{
    position:relative;
    z-index:2;
}
.kr-hero-grid{
    display:grid;
    grid-template-columns:1.2fr .8fr;
    gap:60px;
    align-items:center;
}
.kr-hero-actions{
    display:flex;
    gap:16px;
    margin-top:2rem;
    flex-wrap:wrap;
}
.kr-hero-panel{
  margin-top: 40px;
  padding:28px;
  background:
        radial-gradient(circle at top right,
        rgba(255,107,0,.08),
        transparent 35%),
        rgba(36,32,30,.92);
}
.kr-studio-card{
    padding:1.5rem;
}
.kr-waveform{
    display:flex;
    gap:6px;
    height:46px;
    align-items:flex-end;
    margin-bottom:1.4rem;
}
.kr-waveform span{
    width:6px;
    border-radius:999px;
    background:var(--kr-orange);
    animation:wave 1.2s ease-in-out infinite;
}
.kr-waveform span:nth-child(1){height:18px;}
.kr-waveform span:nth-child(2){height:42px;}
.kr-waveform span:nth-child(3){height:24px;}
.kr-waveform span:nth-child(4){height:38px;}
.kr-waveform span:nth-child(5){height:20px;}
.kr-waveform span:nth-child(6){height:45px;}
.kr-waveform span:nth-child(7){height:30px;}
@keyframes wave{
    50%{
        transform:scaleY(.45);
    }
}
.kr-hero-mini-grid{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:18px;
    margin-top:22px;
}
.kr-media-mini{
    padding:20px;
    position:relative;
}
.kr-media-mini h3{
    color:#fff;
    font-size:1.15rem;
    margin:.4rem 0;
}
.kr-media-mini p{
    color:rgba(255,255,255,.72);
    font-size:.92rem;
    margin:0;
}
.kr-play-orb{
    position:absolute;
    right:18px;
    bottom:18px;
    width:48px;
    height:48px;
    display:grid;
    place-items:center;
    border-radius:50%;
    background:var(--kr-orange);
    color:#fff;
}
/* ==========================================================================
   Sections
   ========================================================================== */
.kr-section{
    padding:90px 0;
}
.kr-section-soft{
    background:#fff;
}
.kr-section-head{
    display:flex;
    justify-content:space-between;
    align-items:end;
    gap:40px;
    margin-bottom:3rem;
}
/* ==========================================================================
   Mobile
   ========================================================================== */
@media(max-width:991px){
    .kr-hero-grid{
        grid-template-columns:1fr;
    }
    .kr-section-head{
        flex-direction:column;
        align-items:flex-start;
    }
}
@media(max-width:768px){
    .kr-navbar-brand img{
        height:58px;
    }
    .kr-hero{
        padding-top:130px;
    }
    .kr-hero-mini-grid{
        grid-template-columns:1fr;
    }
    .kr-btn{
        width:100%;
    }
    .kr-hero-actions{
        flex-direction:column;
    }
}
/* ==========================================================================
   Kisima UI v2
   Part 2 — 12 Fountains • Events • Blogs
   ========================================================================== */
/* ==========================================================================
   12 FOUNTAINS
   ========================================================================== */
.kr-fountains{
    background:
        radial-gradient(circle at top right,
        rgba(255,107,0,.12),
        transparent 30%),
        #0f1115;
    color:#fff;
}
.kr-fountains .kr-section-title{
    color:#fff;
}
.kr-fountains .kr-section-copy{
    color:rgba(255,255,255,.65);
}
.kr-fountain-number{
    width:90px;
    height:90px;
    border-radius:24px;
    background:var(--kr-orange);
    display:flex;
    align-items:center;
    justify-content:center;
    color:#fff;
    font-size:2rem;
    font-weight:900;
    margin-bottom:18px;
}
.kr-fountain-title{
    color:#fff;
    font-size:clamp(2rem,4vw,3.5rem);
    line-height:.95;
    font-weight:900;
    margin-bottom:22px;
}
.kr-fountain-copy{
    color:rgba(255,255,255,.74);
    font-size:1.08rem;
    line-height:1.8;
    max-width:760px;
}
.kr-fountain-controls{
    display:flex;
    justify-content:center;
    align-items:center;
    gap:20px;
    margin-top:42px;
}
.kr-carousel-btn{
    width:52px;
    height:52px;
    display:grid;
    place-items:center;
    border-radius:50%;
    background:#fff;
    color:#111;
    transition:.25s;
}
.kr-carousel-btn:hover{
    background:var(--kr-orange);
    color:#fff;
    transform:translateY(-2px);
}
.kr-fountain-progress{
    position:static;
    display:flex;
    gap:8px;
    margin:0;
    width:auto;
}
.kr-fountain-progress li{
    width:10px;
    height:10px;
    border-radius:50%;
    background:rgba(255,255,255,.3);
    border:none;
}
.kr-fountain-progress .active{
    background:var(--kr-orange);
}
/* ==========================================================================
   EVENTS
   ========================================================================== */
.kr-event-grid{
    display:grid;
    grid-template-columns:repeat(3,1fr);
    gap:32px;
}
.kr-event-card{
    display:flex;
    flex-direction:column;
}
.kr-event-image{
    aspect-ratio:16/10;
    overflow:hidden;
}
.kr-event-image img{
    width:100%;
    height:100%;
    object-fit:cover;
    transition:.45s;
}
.kr-event-card:hover img{
    transform:scale(1.06);
}
.kr-event-body{
    padding:28px;
    display:flex;
    flex-direction:column;
    flex:1;
}
.kr-badge{
    display:inline-flex;
    align-self:flex-start;
    padding:8px 14px;
    border-radius:999px;
    background:#fff2e8;
    color:var(--kr-orange);
    font-weight:800;
    font-size:.75rem;
    text-transform:uppercase;
    letter-spacing:.08em;
    margin-bottom:18px;
}
.kr-event-body h3{
    font-size:1.6rem;
    line-height:1.2;
    font-weight:900;
    margin-bottom:18px;
}
.kr-event-meta{
    display:flex;
    flex-direction:column;
    gap:10px;
    color:var(--kr-text-light);
    font-size:.92rem;
    margin-bottom:22px;
}
.kr-event-meta span{
    display:flex;
    align-items:center;
    gap:10px;
}
.kr-event-body p{
    color:var(--kr-text-light);
    flex:1;
}
.kr-read-link{
    margin-top:auto;
    display:inline-flex;
    align-items:center;
    gap:10px;
    color:var(--kr-orange);
    font-weight:800;
}
.kr-read-link:hover{
    gap:16px;
}
/* ==========================================================================
   BLOGS
   ========================================================================== */
.kr-blog-layout{
    display:grid;
    grid-template-columns:1.1fr .9fr;
    gap:36px;
}
.kr-blog-feature{
    padding:42px;
    display:flex;
    flex-direction:column;
}
.kr-blog-feature h3{
    font-size:clamp(2rem,3vw,3rem);
    line-height:1.05;
    font-weight:900;
    margin:18px 0;
}
.kr-blog-feature p{
    color:var(--kr-text-light);
    font-size:1.05rem;
    line-height:1.9;
    flex:1;
}
.kr-blog-meta{
    display:flex;
    gap:12px;
    align-items:center;
    color:var(--kr-text-light);
    font-size:.9rem;
    margin-bottom:18px;
}
.kr-blog-list{
    display:grid;
    gap:22px;
}
.kr-blog-card{
    padding:26px;
    display:flex;
    flex-direction:column;
}
.kr-blog-card h3{
    font-size:1.35rem;
    line-height:1.2;
    margin:14px 0;
    font-weight:800;
}
.kr-blog-card p{
    color:var(--kr-text-light);
    flex:1;
    margin-bottom:20px;
}
.kr-blog-card:hover{
    border-color:rgba(255,107,0,.22);
}
/* ==========================================================================
   Hover glow
   ========================================================================== */
.kr-event-card:hover,
.kr-blog-card:hover,
.kr-blog-feature:hover{
    box-shadow:
        0 25px 70px rgba(0,0,0,.10),
        0 0 0 1px rgba(255,107,0,.08);
}
/* ==========================================================================
   Responsive
   ========================================================================== */
@media(max-width:1100px){
    .kr-blog-layout{
        grid-template-columns:1fr;
    }
    .kr-event-grid{
        grid-template-columns:1fr 1fr;
    }
}
@media(max-width:768px){
    .kr-fountain-shell{
        grid-template-columns:1fr;
        gap:28px;
        padding:30px;
    }
    .kr-event-grid{
        grid-template-columns:1fr;
    }
    .kr-blog-feature{
        padding:30px;
    }
}
/* ==========================================================================
   Kisima UI v2
   Part 3 — Shows • Social • Footer • Polish
   ========================================================================== */
/* ==========================================================================
   SHOWS
   ========================================================================== */
.kr-shows{
    background:
        linear-gradient(rgba(15,17,21,.88),
        rgba(15,17,21,.94));
    color:#fff;
}
.kr-shows .kr-section-title{
    color:#fff;
}
.kr-shows .kr-section-copy{
    color:rgba(255,255,255,.65);
}
.kr-show-row{
    display:grid;
    grid-template-columns:repeat(auto-fit,minmax(260px,1fr));
    gap:28px;
}
.kr-show-card{
    position:relative;
    overflow:hidden;
    border-radius:26px;
    aspect-ratio:3/4;
    background:#111;
    cursor:pointer;
    transition:.35s;
}
.kr-show-card img{
    width:100%;
    height:100%;
    object-fit:cover;
    transition:transform .45s;
}
.kr-show-overlay{
    position:absolute;
    inset:0;
    display:flex;
    flex-direction:column;
    justify-content:flex-end;
    padding:28px;
    background:
        linear-gradient(
            transparent 35%,
            rgba(0,0,0,.82) 75%,
            rgba(0,0,0,.95)
        );
    transition:.35s;
}
.kr-show-overlay h3{
    color:#fff;
    font-size:1.55rem;
    font-weight:900;
    margin:16px 0 12px;
}
.kr-show-overlay p{
    color:rgba(255,255,255,.74);
    font-size:.92rem;
    line-height:1.6;
}
.kr-show-card:hover{
    transform:translateY(-8px);
    box-shadow:
        0 35px 80px rgba(0,0,0,.35),
        0 0 0 2px rgba(255,107,0,.18);
}
.kr-show-card:hover img{
    transform:scale(1.08);
}
/* ==========================================================================
   SOCIAL
   ========================================================================== */
.kr-social-grid{
    display:grid;
    grid-template-columns:repeat(auto-fit,minmax(340px,1fr));
    gap:28px;
}
.kr-social-card{
    display:flex;
    flex-direction:column;
}
.kr-social-card img{
    width:100%;
    aspect-ratio:16/10;
    object-fit:cover;
}
.kr-social-body{
    padding:26px;
    display:flex;
    flex-direction:column;
    flex:1;
}
.kr-social-body h3{
    margin:16px 0;
    font-size:1.3rem;
    font-weight:800;
}
.kr-social-body p{
    color:var(--kr-text-light);
    line-height:1.8;
    flex:1;
}
.kr-social-card:hover{
    transform:translateY(-6px);
}
/* ==========================================================================
   FOOTER
   ========================================================================== */
.kr-footer{
    background:#0f1115;
    color:#fff;
    padding:80px 0 30px;
}
.kr-footer-grid{
    display:grid;
    grid-template-columns:2fr 1fr 1fr 1fr;
    gap:50px;
    margin-bottom:50px;
}
.kr-footer h4{
    font-size:2rem;
    font-weight:900;
}
.kr-footer h5{
    font-size:1rem;
    margin-bottom:20px;
    color:#fff;
}
.kr-footer p{
    color:rgba(255,255,255,.68);
}
.kr-footer-links{
    display:flex;
    flex-direction:column;
    gap:12px;
}
.kr-footer-links a{
    color:rgba(255,255,255,.72);
}
.kr-footer-links a:hover{
    color:var(--kr-orange);
}
.kr-social-icons{
    display:flex;
    gap:14px;
}
.kr-social-icons a{
    width:46px;
    height:46px;
    display:grid;
    place-items:center;
    border-radius:50%;
    background:rgba(255,255,255,.08);
    color:#fff;
    transition:.25s;
}
.kr-social-icons a:hover{
    background:var(--kr-orange);
    transform:translateY(-3px);
}
.kr-footer-bottom{
    border-top:1px solid rgba(255,255,255,.08);
    padding-top:24px;
    display:flex;
    justify-content:space-between;
    align-items:center;
    color:rgba(255,255,255,.55);
    font-size:.9rem;
}
/* ==========================================================================
   GENERAL ANIMATIONS
   ========================================================================== */
.kr-card,
.kr-show-card,
.kr-social-card{
    transition:
        transform .28s ease,
        box-shadow .28s ease,
        border-color .28s ease;
}
.kr-card:hover{
    transform:translateY(-8px);
}
.kr-btn{
    transition:
        transform .25s,
        background .25s,
        box-shadow .25s;
}
.kr-btn:hover{
    transform:translateY(-2px);
}
.kr-section{
    animation:fadeUp .8s ease;
}
@keyframes fadeUp{
    from{
        opacity:0;
        transform:translateY(35px);
    }
    to{
        opacity:1;
        transform:none;
    }
}
/* ==========================================================================
   SCROLLBAR
   ========================================================================== */
::-webkit-scrollbar{
    width:10px;
}
::-webkit-scrollbar-track{
    background:#f1f1f1;
}
::-webkit-scrollbar-thumb{
    background:var(--kr-orange);
    border-radius:999px;
}
/* ==========================================================================
   RESPONSIVE
   ========================================================================== */
@media (max-width:1100px){
    .kr-footer-grid{
        grid-template-columns:repeat(2,1fr);
    }
}
@media (max-width:768px){
    .kr-show-row,
    .kr-social-grid{
        grid-template-columns:1fr;
    }
    .kr-footer-grid{
        grid-template-columns:1fr;
        gap:40px;
    }
    .kr-footer-bottom{
        flex-direction:column;
        gap:15px;
        text-align:center;
    }
}
/* ==========================================================================
   FINAL POLISH
   ========================================================================== */
::selection{
    background:var(--kr-orange);
    color:#fff;
}
.kr-card,
.kr-show-card,
.kr-social-card{
    border:1px solid rgba(15,17,21,.06);
}
.kr-card:hover,
.kr-show-card:hover,
.kr-social-card:hover{
    border-color:rgba(255,107,0,.18);
}
/* ==========================================
   Live Button
   ========================================== */
.kr-nav-live{
    color:#fff !important;
    background:linear-gradient(135deg,#ff7a1a,#ff5c00);
    box-shadow:0 10px 30px rgba(255,107,0,.35);
}
.kr-nav-live:hover{
    color:#fff !important;
    transform:translateY(-2px);
}
.kr-nav-live.is-disabled{
    opacity:.75;
    color:#fff !important;
    background:rgba(255,107,0,.55);
    cursor:not-allowed;
}
.kr-nav-live.is-disabled .kr-live-dot{
    background:#8b8b8b;
    animation:none;
}
.kr-nav-live{
    margin-left:32px;
    padding:12px 22px;
    border-radius:999px;
    font-size:.95rem;
    font-weight:700;
    white-space:nowrap;
}
.kr-nav {
  display: grid;
  grid-template-columns: 220px 1fr 220px;
  align-items: center;
  height: 88px;
}
.kr-logo {
  justify-self: start;
}
.kr-nav-links {
  justify-self: center;
}
.kr-nav-live {
  justify-self: end;
}
.kr-hero {
  min-height: 100vh;
  padding-top: 150px;
}
.kr-hero::before{
    content:"";
    position:absolute;
    left:-200px;
    top:120px;
    width:700px;
    height:700px;
    background:
        radial-gradient(circle,
        rgba(255,107,0,.08),
        transparent 70%);
    filter:blur(80px);
}
.kr-hero-grid {
  align-items: center;
}
.kr-hero-title {
  max-width: 760px;
  line-height:.88;
  letter-spacing:-.055em;
}
.kr-hero-subtitle {
  max-width:600px;
}
@media (max-width: 992px) {
  .kr-nav {
    display: flex;
  }
}
.kr-hero-kicker {
  color: rgba(255, 255, 255, 0.55);
}
.kr-media-mini small {
  color: rgba(255,255,255,.55);
  font-weight: 700;
}
.kr-media-mini h3 {
  color: #fff;
}
.kr-media-mini p {
  color: rgba(255,255,255,.72);
}
.kr-hero-kicker {
  color: rgba(255, 255, 255, 0.58);
  font-weight: 500;
}
.kr-media-mini small {
  color: rgba(255, 255, 255, 0.55);
  font-size: 0.72rem;
  font-weight: 700;
  text-transform: uppercase;
}
.kr-media-mini h3 {
  color: #fff;
}
.kr-media-mini p {
  color: rgba(255, 255, 255, 0.72);
}
.kr-menu-button.open span:nth-child(1){
    transform:translateY(10px) rotate(45deg);
}
.kr-menu-button.open span:nth-child(2){
    opacity:0;
}
.kr-menu-button.open span:nth-child(3){
    transform:translateY(-10px) rotate(-45deg);
}
.kr-mobile-menu{
    max-height:0;
    overflow:hidden;
    opacity:0;
    transition:
        max-height .35s,
        opacity .35s;
}
.kr-mobile-menu.open{
    max-height:400px;
    opacity:1;
}
.kr-logo{
    display:flex;
    align-items:center;
}
.kr-logo img{
    transition:transform .25s;
}
.kr-logo:hover img{
    transform:scale(1.04);
}
.kr-btn{
    transition:
    transform .25s,
    box-shadow .25s;
}
.kr-btn:hover{
    transform:translateY(-3px);
}
.kr-hero-kicker{
    display:inline-flex;
    align-items:center;
    gap:.7rem;
    color:rgba(255,255,255,.62);
    font-size:.9rem;
    font-weight:600;
    letter-spacing:.08em;
    text-transform:uppercase;
}
.kr-hero-kicker .kr-live-dot{
    width:8px;
    height:8px;
    border-radius:50%;
    background:var(--kr-orange);
    display:inline-block;
    flex:none;
    box-shadow:0 0 8px rgba(255,107,0,.8);
    animation:heroPulse 1.8s infinite;
}
@keyframes heroPulse{
    0%{
        transform:scale(1);
        opacity:1;
    }
    50%{
        transform:scale(1.35);
        opacity:.55;
    }
    100%{
        transform:scale(1);
        opacity:1;
    }
}
.kr-status-badge{
    font-size:.72rem;
    padding:3px 8px;
    border-radius:999px;
    background:rgba(255,255,255,.15);
    color:rgba(255,255,255,.75);
}
.kr-status-badge.live{
    background:#1b8f3c;
    color:#fff;
}
.kr-status-badge.offline{
    background:rgba(255,255,255,.12);
    color:rgba(255,255,255,.75);
}
.kr-nav-live .kr-live-dot{
    width:10px;
    height:10px;
    border-radius:50%;
    background:#3cff6d;
}
.live-link.is-disabled::after {
  content: none !important;
}
.kr-status-badge{
    display:inline-flex;
    align-items:center;
    gap:6px;
    padding:3px 10px;
    border-radius:999px;
    font-size:.72rem;
    font-weight:700;
    line-height:1;
}
.kr-status-badge.live{
    color:#d9ffe5;
    background:rgba(29,185,84,.18);
    border:1px solid rgba(29,185,84,.35);
}
.kr-status-badge.offline{
    color:#d0d0d0;
    background:rgba(255,255,255,.10);
    border:1px solid rgba(255,255,255,.12);
}
.kr-status-badge.live::before,
.kr-status-badge.offline::before{
    content:"";
    width:7px;
    height:7px;
    border-radius:50%;
}
.kr-status-badge.live::before{
    background:#1db954;
    box-shadow:0 0 8px rgba(29,185,84,.8);
    animation:krPulse 1.6s infinite;
}
.kr-status-badge.offline::before{
    background:#888;
}
.kr-hero-panel{
    position:relative;
    overflow:hidden;
}
.kr-hero-panel::before{
    content:"";
    position:absolute;
    inset:0;
    background:
        linear-gradient(
            rgba(15,17,21,.35),
            rgba(15,17,21,.55)
        ),
        url("/static/images/header.png");
    background-size:cover;
    background-position:right center;
    opacity:.28;
    pointer-events:none;
}
/* ===========================
   12 Fountains
=========================== */
.kr-fountains {
  background:
    radial-gradient(circle at 20% 10%, rgba(255, 107, 0, .16), transparent 30%),
    linear-gradient(135deg, #0f1115, #17110d);
  color: #fff;
  position: relative;
  overflow: hidden;
  padding-top: 120px;
}
.kr-fountains .kr-section-title {
  color: #fff;
}
.kr-fountains .kr-section-copy {
  color: rgba(255, 255, 255, .65);
}
.kr-fountain-shell {
  display: grid;
  grid-template-columns: 180px 1fr;
  gap: 48px;
  padding: 54px;
  background:
    linear-gradient(135deg, rgba(255, 255, 255, .10), rgba(255, 255, 255, .04));
  border: 1px solid rgba(255, 255, 255, .12);
  border-radius: 34px;
  box-shadow: 0 30px 90px rgba(0, 0, 0, .35);
  min-height:280px;
  padding:42px 48px;
}
.kr-fountain-number {
  width: 110px;
  height: 110px;
  display: grid;
  place-items: center;
  border-radius: 30px;
  background: linear-gradient(135deg, #ff7a1a, #ff5c00);
  color: #fff;
  font-size: 2.4rem;
  font-weight: 900;
  box-shadow: 0 22px 55px rgba(255, 107, 0, .28);
  margin-bottom: 18px;
}
.kr-fountain-title {
  color: #fff;
  font-size: clamp(2.3rem, 5vw, 4.2rem);
  line-height: .95;
  font-weight: 900;
  letter-spacing: -.055em;
  margin-bottom: 22px;
  font-size:clamp(2.8rem,4vw,3.8rem);
  margin-bottom:16px;
}
.kr-fountain-title::after{
    content:"";
    display:block;
    width:72px;
    height:4px;
    margin-top:16px;
    border-radius:999px;
    background:linear-gradient(90deg,#ff6b00,#ffb067);
}
.kr-fountain-copy {
  color: rgba(255, 255, 255, .72);
  font-size: 1.08rem;
  line-height: 1.85;
  max-width: 760px;
}
.kr-fountain-controls {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 18px;
  margin-top: 34px;
}
.kr-carousel-btn {
  width: 52px;
  height: 52px;
  display: grid;
  place-items: center;
  border-radius: 50%;
  background: rgba(255, 255, 255, .10);
  border: 1px solid rgba(255, 255, 255, .16);
  color: #fff;
}
.kr-carousel-btn:hover {
  background: #ff6b00;
  color: #fff;
  transform: translateY(-2px);
}
.kr-fountain-progress {
  position: static;
  display: flex;
  align-items: center;
  gap: 8px;
  margin: 0;
}
.kr-fountain-progress li {
  width: 9px;
  height: 9px;
  border: 0;
  border-radius: 999px;
  background: rgba(255, 255, 255, .28);
}
.kr-fountain-progress li.active {
  width: 28px;
  background: #ff6b00;
}
#kisimaFountains .carousel-item.active {
  display: block;
}
@media (max-width: 768px) {
  .kr-fountain-shell {
    grid-template-columns: 1fr;
    gap: 26px;
    padding: 30px;
  }
  .kr-fountain-number {
    width: 82px;
    height: 82px;
    font-size: 1.7rem;
    border-radius: 22px;
  }
  .kr-fountain-controls {
    gap: 12px;
  }
  .kr-fountain-progress {
    max-width: 150px;
    flex-wrap: wrap;
    justify-content: center;
  }
}
#kisimaFountains .carousel-item {
  display: none;
}
.kr-fountain-progress {
  position: static;
  display: flex;
  align-items: center;
  gap: 8px;
  margin: 0;
  padding: 0;
  list-style: none;
}
.kr-fountain-progress li {
  width: 10px;
  height: 10px;
  border: 0;
  border-radius: 999px;
  background: rgba(255,255,255,.28);
  text-indent: -9999px;
  overflow: hidden;
}
.kr-fountain-progress li.active {
  width: 28px;
  background: var(--kr-orange);
}
.kr-carousel-btn{
    width:58px;
    height:58px;
    border-radius:50%;
    background:rgba(255,255,255,.08);
    border:1px solid rgba(255,255,255,.12);
    transition:.25s;
}
.kr-carousel-btn:hover{
    background:#ff6b00;
    transform:translateY(-2px);
    box-shadow:0 12px 28px rgba(255,107,0,.35);
}
.carousel-item.active .kr-fountain-shell{
    animation:fountainFade .45s ease;
}
@keyframes fountainFade{
    from{
        opacity:0;
        transform:translateY(18px);
    }
    to{
        opacity:1;
        transform:none;
    }
}
.kr-fountain-number{
    width:120px;
    height:120px;
    display:flex;
    align-items:center;
    justify-content:center;
    font-size:3rem;
    font-weight:900;
    border-radius:32px;
    background:linear-gradient(135deg,#ff7a1a,#ff5c00);
    color:#fff;
    box-shadow:0 18px 40px rgba(255,107,0,.35);
    margin-bottom:22px;
}
.kr-fountain-index{
    width:180px;
    display:flex;
    flex-direction:column;
    align-items:flex-start;
    justify-content:center;
}
.kr-fountain-category{
    margin-top:6px;
    color:var(--kr-orange);
    font-size:.78rem;
    font-weight:800;
    letter-spacing:.22em;
    text-transform:uppercase;
}
.kr-fountain-name{
    margin-top:14px;
    font-size:1.5rem;
    font-weight:800;
    color:#fff;
    line-height:1.2;
}
.kr-fountain-title{
    font-size:2.8rem;
    margin-bottom:18px;
}
.kr-fountain-shell{
    grid-template-columns:220px 1fr;
}
.kr-fountain-index{
    padding-right:36px;
    border-right:1px solid rgba(255,255,255,.08);
}
.kr-fountain-content{
    padding-left:48px;
}
/* ===========================
   12 Fountains — magazine card
=========================== */
.kr-fountain-shell {
  display: grid;
  grid-template-columns: 260px 1fr;
  min-height: 300px;
  padding: 0;
  overflow: hidden;
  background:
    linear-gradient(135deg, rgba(255,255,255,.09), rgba(255,255,255,.035));
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 34px;
  box-shadow: 0 30px 90px rgba(0,0,0,.35);
}
.kr-fountain-index {
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding: 42px;
  background:
    radial-gradient(circle at 20% 15%, rgba(255,255,255,.22), transparent 34%),
    linear-gradient(160deg, #ff8a22 0%, #ff6b00 55%, #d94f00 100%);
  color: #fff;
}
.kr-fountain-number {
  background: transparent;
  box-shadow: none;
  width: auto;
  height: auto;
  border-radius: 0;
  display: block;
  font-size: 4.6rem;
  line-height: .85;
  font-weight: 950;
  letter-spacing: -.08em;
  margin-bottom: 28px;
}
.kr-fountain-category {
  color: rgba(255,255,255,.78);
  font-size: .72rem;
  font-weight: 900;
  letter-spacing: .24em;
  text-transform: uppercase;
  margin-bottom: 14px;
}
.kr-fountain-name {
  color: #fff;
  font-size: 1.6rem;
  font-weight: 900;
  line-height: 1.1;
}
.kr-fountain-content {
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding: 56px 70px;
}
.kr-fountain-title {
  color: #fff;
  font-size: clamp(2.2rem, 4vw, 3.6rem);
  line-height: 1;
  font-weight: 900;
  letter-spacing: -.05em;
  margin-bottom: 18px;
}
.kr-fountain-title::after {
  content: "";
  display: block;
  width: 72px;
  height: 4px;
  margin-top: 18px;
  border-radius: 999px;
  background: linear-gradient(90deg, #ff6b00, #ffb067);
}
.kr-fountain-copy {
  color: rgba(255,255,255,.72);
  font-size: 1.05rem;
  line-height: 1.85;
  max-width: 760px;
}
@media (max-width: 768px) {
  .kr-fountain-shell {
    grid-template-columns: 1fr;
  }
  .kr-fountain-index {
    padding: 30px;
  }
  .kr-fountain-number {
    font-size: 3.4rem;
    margin-bottom: 18px;
  }
  .kr-fountain-content {
    padding: 34px 30px;
  }
}
.kr-fountain-index{
    position:relative;
    display:flex;
    flex-direction:column;
    justify-content:center;
    padding:48px 38px;
    background:
        linear-gradient(
            180deg,
            rgba(43,39,36,.96),
            rgba(24,22,20,.98)
        );
    border-right:1px solid rgba(255,255,255,.08);
    overflow:hidden;
}
.kr-fountain-index::before{
    content:"";
    position:absolute;
    left:0;
    top:0;
    bottom:0;
    width:6px;
    background:
        linear-gradient(
            180deg,
            #ff9835,
            #ff6b00
        );
}
.kr-fountain-number{
    width:auto;
    height:auto;
    background:none;
    box-shadow:none;
    border-radius:0;
    margin:0 0 30px;
    color:#fff;
    font-size:5rem;
    font-weight:900;
    letter-spacing:-.08em;
    line-height:.85;
}
.kr-fountain-category{
    color:#ff7d1a;
    font-size:.72rem;
    font-weight:800;
    letter-spacing:.32em;
    text-transform:uppercase;
    margin-bottom:18px;
}
.kr-fountain-name{
    color:#fff;
    font-size:1.65rem;
    font-weight:800;
    line-height:1.2;
}
.kr-fountain-shell{
    display:grid;
    grid-template-columns:250px 1fr;
    min-height:300px;
    padding:0;
    overflow:hidden;
    border-radius:32px;
    border:1px solid rgba(255,255,255,.08);
    background:
        radial-gradient(circle at 30% 0%,rgba(255,107,0,.08),transparent 35%),
        linear-gradient(
            135deg,
            rgba(255,255,255,.08),
            rgba(255,255,255,.03)
        );
    backdrop-filter:blur(18px);
    box-shadow:
        0 25px 70px rgba(0,0,0,.35);
}
.kr-fountain-shell {
  grid-template-columns: 320px 1fr;
}
.kr-fountain-index {
  min-width: 0;
  overflow: hidden;
}
.kr-fountain-name {
  max-width: 100%;
  overflow-wrap: anywhere;
  word-break: normal;
}
.kr-fountain-name {
  font-size: clamp(1.15rem, 1.7vw, 1.55rem);
  line-height: 1.15;
}
@media (max-width: 768px) {
  .kr-fountain-shell {
    grid-template-columns: 1fr;
  }
}
.kr-fountain-content {
  justify-content: center;
  padding: 48px 64px;
}

.kr-fountain-label {
  margin-bottom: 28px;
}

.kr-fountain-title {
  font-size: clamp(2.4rem, 4vw, 3.4rem);
  margin-bottom: 18px;
}

.kr-fountain-copy {
  max-width: 680px;
}
.kr-fountain-shell {
  grid-template-columns: 280px 1fr;
}
.kr-event-grid {
  grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
}

.kr-event-grid:has(.kr-event-card:only-child) {
  max-width: 720px;
}
.kr-blog-feature {
  min-height: 360px;
}

.kr-blog-card {
  min-height: 0;
}
.kr-social-card > img {
  height: 260px;
  object-fit: cover;
}
.kr-event-content{

    padding:42px;

    display:flex;

    flex-direction:column;

    justify-content:center;

}
.kr-event-image{

    height:100%;

    min-height:340px;

    object-fit:cover;

    border-radius:28px 0 0 28px;

}
/* ==========================================
   FEATURED EVENT
========================================== */

.kr-feature-event{
    display:grid;
    grid-template-columns:360px 1fr;
    align-items:stretch;

    overflow:hidden;

    border-radius:30px;

    background:#fff;

    box-shadow:0 25px 70px rgba(0,0,0,.08);
}

.kr-feature-event-image{
    min-height:360px;
}

.kr-feature-event-image img{
    width:100%;
    height:100%;
    display:block;
    object-fit:cover;
}

.kr-feature-event-content{
    padding:3.5rem;
    display:flex;
    flex-direction:column;
    justify-content:center;
}

.kr-feature-event-content h3{
    font-size:2.5rem;
    font-weight:800;
    margin:1rem 0;
}

.kr-event-meta{
    display:flex;
    flex-wrap:wrap;
    gap:1.25rem;

    margin-bottom:1.5rem;

    color:#6b7280;
    font-size:.95rem;
}

.kr-event-meta span{
    display:flex;
    align-items:center;
    gap:.45rem;
}

.kr-tag{
    display:inline-flex;
    align-items:center;

    width:max-content;

    padding:.45rem .9rem;

    border-radius:999px;

    background:#fff3eb;

    color:var(--kr-orange);

    font-size:.78rem;
    font-weight:700;
    letter-spacing:.08em;
    text-transform:uppercase;
}

.kr-link{
    display:inline-flex;
    align-items:center;
    gap:.5rem;

    margin-top:1rem;

    color:var(--kr-orange);

    font-weight:700;

    text-decoration:none;
}
.kr-empty-event{

    background:#fff;

    border-radius:32px;

    padding:5rem 4rem;

    text-align:center;

    box-shadow:0 30px 80px rgba(0,0,0,.08);

}

.kr-empty-event-icon{

    width:90px;
    height:90px;

    margin:0 auto 2rem;

    border-radius:50%;

    background:#fff3eb;

    color:var(--kr-orange);

    display:flex;
    align-items:center;
    justify-content:center;

    font-size:2rem;

}
.kr-section-light {
  padding-top: 140px;
}

.kr-section-light .container {
  width: min(1200px, calc(100% - 40px));
  margin-inline: auto;
}

.kr-empty-event {
  margin-top: 48px;
}

.kr-empty-event h3{

    font-size:2rem;
    font-weight:800;

    margin:1.5rem 0 1rem;

}

.kr-empty-event p{

    max-width:620px;

    margin:0 auto 2rem;

    color:#64748b;

}
.kr-feature-event {
  grid-template-columns: 360px 1fr;
  max-width: 100%;
}

.kr-feature-event-image {
  background: #111;
}

.kr-feature-event-content {
  padding: 4rem 4.5rem;
}

.kr-feature-event-content h3 {
  font-size: clamp(2rem, 4vw, 3.4rem);
  line-height: 1;
}

.kr-event-meta {
  display: grid;
  gap: 0.9rem;
}

.kr-feature-event-content p {
  max-width: 620px;
  font-size: 1.1rem;
  line-height: 1.8;
}

@media (max-width: 900px) {
  .kr-feature-event {
    grid-template-columns: 1fr;
  }

  .kr-feature-event-image {
    max-height: 520px;
  }
}
.kr-blogs {
  background: #f4f7fb;
  padding-top: 140px;
}
.kr-blog-card {
  padding: 24px;
}

.kr-blog-card h3 {
  margin-top: 12px;
}

.kr-blog-layout {
  display: grid;
  grid-template-columns: 1.05fr 0.95fr;
  gap: 32px;
}

.kr-blog-feature,
.kr-blog-card {
  display: flex;
  flex-direction: column;
}

.kr-blog-feature {
  min-height: 460px;
  padding: 44px;
  background:
    radial-gradient(circle at top right, rgba(255,107,0,.14), transparent 34%),
    #fff;
}

.kr-blog-feature h3 {
  font-size: clamp(2.3rem, 4vw, 3.6rem);
  line-height: 1;
  font-weight: 900;
  letter-spacing: -.05em;
  margin: 24px 0 18px;
}

.kr-blog-feature h3 a,
.kr-blog-card h3 a {
  color: var(--kr-text);
}

.kr-blog-feature p {
  color: var(--kr-text-light);
  font-size: 1.08rem;
  line-height: 1.9;
  max-width: 680px;
  flex: 1;
}

.kr-blog-list {
  display: grid;
  grid-template-columns: 1fr;
  gap: 20px;
}

.kr-blog-card {
  min-height: 0;
  padding: 28px;
}

.kr-blog-card h3 {
  font-size: 1.35rem;
  line-height: 1.15;
  font-weight: 850;
  margin: 16px 0 10px;
}

.kr-blog-card p {
  color: var(--kr-text-light);
  line-height: 1.75;
  flex: 1;
}

.kr-blog-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  color: var(--kr-text-light);
  font-size: .85rem;
  font-weight: 600;
}

@media (max-width: 900px) {
  .kr-blog-layout {
    grid-template-columns: 1fr;
  }

  .kr-blog-feature {
    min-height: auto;
    padding: 32px;
  }
}
.kr-blog-list {
  gap: 18px;
}
/* 12 Fountains: fix long text and left index */
.kr-fountain-name {
  font-size: clamp(1rem, 1.4vw, 1.35rem);
  overflow-wrap: anywhere;
}

.kr-fountain-title {
  max-width: 100%;
  overflow-wrap: anywhere;
}

.kr-fountain-content {
  min-width: 0;
}

/* Keep sections from feeling too spaced out */
.kr-section {
  padding: 82px 0;
}

/* Events: image/card balance */
.kr-feature-event {
  grid-template-columns: 330px 1fr;
}

.kr-feature-event-image img {
  object-position: top center;
}

/* Blogs: reduce feature empty height */
.kr-blog-feature {
  min-height: 420px;
}

.kr-blog-feature p,
.kr-blog-card p {
  overflow-wrap: anywhere;
}

/* Socials: less tall cards */
.kr-social-card > img {
  height: 230px;
  object-fit: cover;
}

.kr-social-body p {
  display: -webkit-box;
  -webkit-line-clamp: 9;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
/* ==========================
   12 Fountains
   ========================== */

.kr-fountain-name {
    font-size: clamp(1rem, 1.3vw, 1.35rem);
    line-height: 1.3;
    overflow-wrap: anywhere;
}

.kr-fountain-title {
    max-width: 100%;
    line-height: 1.05;
    overflow-wrap: anywhere;
}

.kr-fountain-content {
    min-width: 0;
}

/* ==========================
   Global Section Spacing
   ========================== */

.kr-section {
    padding: 6rem 0;
}

/* ==========================
   Events
   ========================== */

.kr-feature-event {
    grid-template-columns: 330px 1fr;
    align-items: stretch;
}

.kr-feature-event-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: top center;
}

/* ==========================
   Blogs
   ========================== */

.kr-blog-feature {
    min-height: 420px;
}

.kr-blog-feature p,
.kr-blog-card p {
    overflow-wrap: anywhere;
}

.kr-blog-feature-copy {
    display: -webkit-box;
    -webkit-line-clamp: 8;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

/* ==========================
   Socials
   ========================== */

.kr-social-card > img {
    height: 230px;
    width: 100%;
    object-fit: cover;
}

.kr-social-body p {
    display: -webkit-box;
    -webkit-line-clamp: 9;
    -webkit-box-orient: vertical;
    overflow: hidden;
}
.kr-blog-author{
    font-weight:600;
    color:var(--kr-orange);
}

.kr-blog-meta{
    display:flex;
    gap:.75rem;
    flex-wrap:wrap;
    color:#6b7280;
    font-size:.9rem;
}
/* ==========================================
   Shows
========================================== */

.kr-shows {
  background:
    radial-gradient(circle at top left, rgba(255,107,0,.14), transparent 28%),
    linear-gradient(135deg, #101216, #1b1f25);
  color: #fff;
}

.kr-shows .kr-section-title {
  color: #fff;
}

.kr-shows .kr-section-copy {
  color: rgba(255,255,255,.65);
}

.kr-show-row {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 24px;
}

.kr-show-card {
  position: relative;
  aspect-ratio: 3 / 4;
  overflow: hidden;
  border-radius: 22px;
  background: #111;
  box-shadow: 0 24px 60px rgba(0,0,0,.35);
}

.kr-show-card img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform .45s ease;
}

.kr-show-overlay {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  padding: 22px;
  background:
    linear-gradient(
      to top,
      rgba(0,0,0,.92),
      rgba(0,0,0,.55) 40%,
      rgba(0,0,0,.05)
    );
}

.kr-show-overlay h3 {
  color: #fff;
  font-size: 1.25rem;
  font-weight: 850;
  line-height: 1.1;
  margin: 10px 0 8px;
}

.kr-show-overlay p {
  color: rgba(255,255,255,.72);
  font-size: .85rem;
  line-height: 1.5;
  margin: 0;
}

.kr-show-card:hover img {
  transform: scale(1.08);
}

.kr-show-card:hover {
  box-shadow:
    0 30px 80px rgba(0,0,0,.45),
    0 0 0 1px rgba(255,107,0,.28);
}

@media (max-width: 1100px) {
  .kr-show-row {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 640px) {
  .kr-show-row {
    grid-template-columns: 1fr;
  }
}
.kr-show-overlay {
  padding: 20px;
  background:
    linear-gradient(
      to top,
      rgba(0,0,0,.9) 0%,
      rgba(0,0,0,.65) 34%,
      rgba(0,0,0,.08) 70%
    );
}

.kr-show-overlay .kr-badge {
  padding: 7px 16px;
  font-size: .72rem;
}

.kr-show-overlay h3 {
  font-size: 1.35rem;
  text-shadow: 0 2px 12px rgba(0,0,0,.65);
}

.kr-show-overlay p {
  font-size: .9rem;
  font-weight: 600;
  text-shadow: 0 2px 10px rgba(0,0,0,.6);
}
/* ==========================================
   Socials
========================================== */

.kr-social-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 28px;
}

.kr-social-card {
  display: flex;
  flex-direction: column;
  border-radius: 24px;
  overflow: hidden;
  background: #fff;
  box-shadow: 0 22px 60px rgba(0,0,0,.08);
}

.kr-social-card > img {
  width: 100%;
  height: 250px;
  object-fit: cover;
}

.kr-social-body {
  padding: 24px;
  display: flex;
  flex-direction: column;
  flex: 1;
}

.kr-social-body p {
  color: var(--kr-text-light);
  line-height: 1.7;
  display: -webkit-box;
  -webkit-line-clamp: 8;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.kr-social-body h3 {
  font-size: 1.25rem;
  line-height: 1.25;
  margin: 14px 0;
}

.kr-social-body .kr-read-link {
  margin-top: auto;
}

@media (max-width: 1000px) {
  .kr-social-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 640px) {
  .kr-social-grid {
    grid-template-columns: 1fr;
  }

  .kr-social-card > img {
    height: 220px;
  }
}
.kr-social-body {
  padding: 22px;
}

.kr-social-body p {
  font-size: 0.95rem;
  line-height: 1.6;
  color: var(--kr-text-light);

  display: -webkit-box;
  -webkit-line-clamp: 7;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.kr-social-card {
  min-height: 0;
}

.kr-social-card > img {
  height: 220px;
}

.kr-social-body .kr-read-link {
  margin-top: 18px;
}

/* ==========================================
   Blog index + blog detail
========================================== */

.kr-page-hero {
  padding: 170px 0 90px;
}

.kr-page-hero-dark {
  background:
    radial-gradient(circle at 80% 20%, rgba(255,107,0,.16), transparent 28%),
    linear-gradient(135deg, #101216, #17110d);
  color: #fff;
}

.kr-page-title {
  color: #fff;
  font-size: clamp(3rem, 7vw, 6rem);
  line-height: .92;
  font-weight: 900;
  letter-spacing: -.06em;
  margin: 1rem 0;
}

.kr-page-intro {
  max-width: 720px;
  color: rgba(255,255,255,.72);
  font-size: 1.15rem;
}

.kr-blogs-listing {
  background: #f4f7fb;
}

.kr-blog-index-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 28px;
}

.kr-blog-index-card {
  display: flex;
  flex-direction: column;
}

.kr-blog-index-image {
  height: 230px;
  overflow: hidden;
}

.kr-blog-index-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.kr-blog-index-body {
  padding: 28px;
  display: flex;
  flex-direction: column;
  flex: 1;
}

.kr-blog-index-body h2 {
  font-size: 1.55rem;
  line-height: 1.15;
  font-weight: 850;
  margin: 16px 0 10px;
}

.kr-blog-index-body p {
  color: var(--kr-text-light);
  line-height: 1.75;
}

.kr-blog-index-body .kr-read-link {
  margin-top: auto;
}

.kr-load-more-wrap {
  display: flex;
  justify-content: center;
  margin-top: 44px;
}

.kr-article-hero {
  padding: 170px 0 70px;
  background:
    radial-gradient(circle at 80% 15%, rgba(255,107,0,.14), transparent 28%),
    linear-gradient(135deg, #101216, #17110d);
  color: #fff;
}

.kr-back-link {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  color: rgba(255,255,255,.72);
  font-weight: 700;
  margin-bottom: 34px;
}

.kr-back-link:hover {
  color: var(--kr-orange);
}

.kr-article-title {
  color: #fff;
  max-width: 960px;
  font-size: clamp(3rem, 7vw, 6rem);
  line-height: .92;
  font-weight: 900;
  letter-spacing: -.06em;
  margin: 18px 0;
}

.kr-article-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  color: rgba(255,255,255,.68);
  font-size: .95rem;
}

.kr-article-meta strong {
  color: var(--kr-orange);
}

.kr-article-intro {
  max-width: 760px;
  margin-top: 28px;
  color: rgba(255,255,255,.78);
  font-size: 1.25rem;
  line-height: 1.8;
}

.kr-article-cover {
  margin-top: -40px;
  border-radius: 30px;
  overflow: hidden;
  box-shadow: 0 30px 90px rgba(0,0,0,.18);
}

.kr-article-cover img {
  width: 100%;
  display: block;
}

.kr-article-body {
  max-width: 820px;
  margin: 70px auto;
  font-size: 1.08rem;
  line-height: 1.9;
  color: var(--kr-text);
}

.kr-article-body p {
  margin-bottom: 1.6rem;
}

.kr-article-gallery {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 24px;
  margin-top: 50px;
}

.kr-article-gallery figure {
  margin: 0;
}

.kr-article-gallery img {
  border-radius: 20px;
  width: 100%;
}

.kr-article-gallery figcaption {
  color: var(--kr-text-light);
  font-size: .9rem;
  margin-top: 10px;
}

.kr-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 50px;
}

.kr-tags a {
  padding: 8px 14px;
  border-radius: 999px;
  background: #fff3eb;
  color: var(--kr-orange);
  font-weight: 700;
  font-size: .85rem;
}

@media (max-width: 1000px) {
  .kr-blog-index-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 640px) {
  .kr-blog-index-grid,
  .kr-article-gallery {
    grid-template-columns: 1fr;
  }
}
.kr-blog-index-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 26px;
}

.kr-blog-index-card {
  display: grid;
  grid-template-columns: 320px 1fr;
  min-height: 260px;
}

.kr-blog-index-image {
  height: 100%;
  min-height: 260px;
}

.kr-blog-index-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.kr-blog-index-body {
  padding: 34px;
}

@media (max-width: 760px) {
  .kr-blog-index-card {
    grid-template-columns: 1fr;
  }

  .kr-blog-index-image {
    min-height: 220px;
  }
}
.kr-blog-index-card:not(:has(.kr-blog-index-image)) {
  display: block;
  padding: 38px;
}

.kr-blog-index-card:not(:has(.kr-blog-index-image)) .kr-blog-index-body {
  padding: 0;
  max-width: 760px;
}
.kr-blog-index-body > p:last-of-type {
  display: -webkit-box;
  -webkit-line-clamp: 4;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.kr-blog-index-card:not(:has(.kr-blog-index-image)) {
  padding: 34px 38px;
}

.kr-blog-index-card:not(:has(.kr-blog-index-image)) .kr-blog-index-body {
  max-width: 850px;
}

.kr-blog-index-body .kr-blog-intro {
  margin-bottom: 1.3rem;
}

.kr-blog-index-body > p:last-of-type {
  max-width: 850px;
  margin-bottom: 1.5rem;
}
.kr-event-list-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 28px;
  margin-top: 34px;
}

.kr-event-list-card {
  display: grid;
  grid-template-columns: 320px 1fr;
  overflow: hidden;
}

.kr-event-list-image {
  height: 100%;
  min-height: 300px;
}

.kr-event-list-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.kr-event-list-body {
  padding: 40px;
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.kr-event-list-body h2 {
  font-size: clamp(2rem, 4vw, 3rem);
}

@media (max-width: 800px) {
  .kr-event-list-card {
    grid-template-columns: 1fr;
  }

  .kr-event-list-image {
    min-height: 260px;
  }
}
.kr-event-card,
.kr-feature-event {
    display:grid;
    grid-template-columns:280px 1fr;
    overflow:hidden;
}

.kr-event-image,
.kr-feature-event-image{
    background:#111;
    display:flex;
    align-items:center;
    justify-content:center;
    padding:20px;
}

.kr-event-image img,
.kr-feature-event-image img{
    width:100%;
    height:100%;
    object-fit:contain;      /* don't crop posters */
    border-radius:14px;
}
.kr-event-body{
    padding:42px 48px;
    display:flex;
    flex-direction:column;
    justify-content:center;
}

.kr-event-body h2,
.kr-event-body h3{
    margin:18px 0;
}

.kr-event-meta{
    display:flex;
    flex-direction:column;
    gap:10px;
    margin:22px 0;
}

.kr-event-card,
.kr-feature-event {
    display:grid;
    grid-template-columns:280px 1fr;
    overflow:hidden;
}

.kr-event-image,
.kr-feature-event-image{
    background:#111;
    display:flex;
    align-items:center;
    justify-content:center;
    padding:20px;
}

.kr-event-image img,
.kr-feature-event-image img{
    width:100%;
    height:100%;
    object-fit:contain;      /* don't crop posters */
    border-radius:14px;
}
.kr-event-body{
    padding:42px 48px;
    display:flex;
    flex-direction:column;
    justify-content:center;
}

.kr-event-body h2,
.kr-event-body h3{
    margin:18px 0;
}

.kr-event-meta{
    display:flex;
    flex-direction:column;
    gap:10px;
    margin:22px 0;
}
/* ==========================
   Event Detail Fix
========================== */

.template-eventpage .kr-event-detail-hero {
  padding: 170px 0 90px;
  background:
    radial-gradient(circle at 82% 20%, rgba(255,107,0,.16), transparent 30%),
    linear-gradient(135deg, #101216, #17110d) !important;
  color: #fff;
}

.template-eventpage .kr-event-detail-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 380px;
  gap: 70px;
  align-items: center;
}

.template-eventpage .kr-article-title {
  color: #fff !important;
}

.template-eventpage .kr-article-intro {
  color: rgba(255,255,255,.75);
}

.template-eventpage .kr-event-detail-meta {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
  margin-top: 38px;
}

.template-eventpage .kr-event-detail-meta div {
  padding: 20px;
  border-radius: 20px;
  background: rgba(255,255,255,.08);
  border: 1px solid rgba(255,255,255,.12);
}

.template-eventpage .kr-event-detail-meta small {
  display: block;
  color: var(--kr-orange);
  text-transform: uppercase;
  font-weight: 800;
  letter-spacing: .14em;
  font-size: .72rem;
}

.template-eventpage .kr-event-detail-meta strong {
  color: #fff;
}

.template-eventpage .kr-event-detail-poster {
  background: #111;
  padding: 18px;
  border-radius: 30px;
  box-shadow: 0 35px 100px rgba(0,0,0,.32);
}

.template-eventpage .kr-event-detail-poster img {
  width: 100%;
  max-height: 560px;
  object-fit: contain;
  border-radius: 20px;
  display: block;
}

.template-eventpage .kr-event-detail-body {
  max-width: 920px;
  margin: 0 auto;
  padding: 56px;
}

@media (max-width: 900px) {
  .template-eventpage .kr-event-detail-grid {
    grid-template-columns: 1fr;
  }

  .template-eventpage .kr-event-detail-meta {
    grid-template-columns: 1fr;
  }
}
.kr-event-detail-poster {
  max-width: 360px;
  justify-self: center;
}

.kr-event-detail-poster img {
  max-height: 460px;
}

.kr-event-detail-body {
  margin-top: 0;
}

.kr-event-detail-body .kr-article-body {
  margin-top: 36px;
}
/* ==========================================
   Blog Detail
========================================== */

.kr-blog-detail-hero {
  padding: 170px 0 90px;
  background:
    radial-gradient(circle at 82% 20%, rgba(255,107,0,.16), transparent 30%),
    linear-gradient(135deg, #101216, #17110d);
  color: #fff;
}

.kr-blog-detail .kr-article-title {
  color: #fff;
  max-width: 980px;
}

.kr-blog-detail .kr-article-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  color: rgba(255,255,255,.68);
  margin-top: 22px;
}

.kr-blog-detail .kr-article-meta strong {
  color: var(--kr-orange);
}

.kr-blog-detail .kr-article-intro {
  max-width: 780px;
  margin-top: 30px;
  color: rgba(255,255,255,.78);
  font-size: 1.25rem;
  line-height: 1.8;
}

.kr-blog-cover-wrap {
  background: #f4f7fb;
}

.kr-blog-cover {
  margin-top: -48px;
  border-radius: 30px;
  overflow: hidden;
  box-shadow: 0 35px 100px rgba(0,0,0,.18);
}

.kr-blog-cover img {
  width: 100%;
  display: block;
}

.kr-blog-detail-card {
  max-width: 920px;
  margin: 0 auto;
  padding: 58px;
}

.kr-blog-detail-card .kr-article-body {
  max-width: 760px;
  margin: 0 auto;
  font-size: 1.08rem;
  line-height: 1.95;
  color: var(--kr-text);
}

.kr-blog-detail-card .kr-article-body p {
  margin-bottom: 1.6rem;
}

.kr-article-gallery {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 24px;
  margin-top: 54px;
}

.kr-article-gallery figure {
  margin: 0;
}

.kr-article-gallery img {
  width: 100%;
  border-radius: 22px;
}

.kr-article-gallery figcaption {
  margin-top: 10px;
  color: var(--kr-text-light);
  font-size: .9rem;
}

.kr-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 50px;
}

.kr-tags a {
  padding: 8px 14px;
  border-radius: 999px;
  background: #fff3eb;
  color: var(--kr-orange);
  font-weight: 700;
  font-size: .85rem;
}

@media (max-width: 700px) {
  .kr-blog-detail-card {
    padding: 34px;
  }

  .kr-article-gallery {
    grid-template-columns: 1fr;
  }
}
