/*
  BY JS 2026-06-05
  르노코리아 다크 디자인 스켈레톤
  - CI4 전역 디자인 레퍼런스
  - 폰트 파일은 포함하지 않고 경로만 정의
*/
@font-face{font-family:"Happiness Sans";font-weight:400;font-style:normal;font-display:swap;src:url("../fonts/happiness-sans/HappinessSans-Regular.woff2") format("woff2"),url("../fonts/happiness-sans/HappinessSans-Regular.woff") format("woff"),url("../fonts/happiness-sans/HappinessSans-Regular.ttf") format("truetype")}
@font-face{font-family:"Happiness Sans";font-weight:700;font-style:normal;font-display:swap;src:url("../fonts/happiness-sans/HappinessSans-Bold.woff2") format("woff2"),url("../fonts/happiness-sans/HappinessSans-Bold.woff") format("woff"),url("../fonts/happiness-sans/HappinessSans-Bold.ttf") format("truetype")}
@font-face{font-family:"Happiness Sans Title";font-weight:700;font-style:normal;font-display:swap;src:url("../fonts/happiness-sans/HappinessSans-Title.woff2") format("woff2"),url("../fonts/happiness-sans/HappinessSans-Title.woff") format("woff"),url("../fonts/happiness-sans/HappinessSans-Title.ttf") format("truetype")}

:root{
  color-scheme:dark;
  --rk-bg:#05070a;--rk-bg-2:#0b0f15;--rk-panel:#111720;--rk-panel-2:#161d28;--rk-panel-glass:rgba(17,23,32,.86);
  --rk-soft:rgba(255,255,255,.045);--rk-soft-2:rgba(255,255,255,.07);--rk-line:rgba(255,255,255,.1);--rk-line-2:rgba(255,255,255,.18);
  --rk-text:#f7f8fa;--rk-muted:#a7b0be;--rk-dim:#737d8c;--rk-disabled:#4f5968;
  --rk-yellow:#f7d100;--rk-yellow-2:#ffe066;--rk-yellow-soft:rgba(247,209,0,.12);--rk-yellow-line:rgba(247,209,0,.42);
  --rk-green:#32d583;--rk-green-soft:rgba(50,213,131,.12);--rk-blue:#68a7ff;--rk-blue-soft:rgba(104,167,255,.12);
  --rk-orange:#ffb020;--rk-orange-soft:rgba(255,176,32,.13);--rk-red:#ff5c5c;--rk-red-soft:rgba(255,92,92,.12);--rk-purple:#a78bfa;--rk-purple-soft:rgba(167,139,250,.13);
  --rk-shadow:0 28px 80px rgba(0,0,0,.42);--rk-shadow-lg:0 34px 96px rgba(0,0,0,.48);--rk-shadow-yellow:0 18px 42px rgba(247,209,0,.2);
  --rk-radius-xl:32px;--rk-radius-lg:22px;--rk-radius-md:15px;--rk-radius-sm:11px;--rk-radius-xs:8px;
  --rk-font:"Happiness Sans","Pretendard","Noto Sans KR","Apple SD Gothic Neo",sans-serif;
  --rk-font-title:"Happiness Sans Title","Happiness Sans","Pretendard","Noto Sans KR",sans-serif;
  --rk-sidebar:280px;--rk-topbar:74px;--rk-ease:cubic-bezier(.22,1,.36,1);
}
*{box-sizing:border-box}html,body{margin:0;min-height:100%}
body{background:radial-gradient(circle at 68% 18%,rgba(247,209,0,.095),transparent 24%),radial-gradient(circle at 24% 74%,rgba(255,255,255,.045),transparent 28%),linear-gradient(135deg,#040609 0%,#101620 52%,#05070a 100%);color:var(--rk-text);font-family:var(--rk-font);font-size:14px;line-height:1.45;word-break:keep-all;-webkit-font-smoothing:antialiased}
body:before{content:"";position:fixed;inset:0;z-index:-2;pointer-events:none;background-image:linear-gradient(rgba(255,255,255,.018) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.014) 1px,transparent 1px);background-size:76px 76px;mask-image:radial-gradient(circle at center,black 0%,transparent 76%)}
body:after{content:"";position:fixed;inset:0;z-index:-1;pointer-events:none;background:linear-gradient(118deg,transparent 0%,rgba(255,255,255,.028) 48%,transparent 49%),linear-gradient(180deg,rgba(255,255,255,.015),transparent 40%,rgba(0,0,0,.22))}
button,input,select,textarea{font:inherit}button{cursor:pointer}a{color:inherit;text-decoration:none}svg{flex:0 0 auto}

.rk-app{min-height:100vh;display:grid;grid-template-columns:var(--rk-sidebar) minmax(0,1fr)}
.rk-sidebar{position:sticky;top:0;height:100vh;overflow:auto;border-right:1px solid var(--rk-line);background:rgba(5,7,10,.62);backdrop-filter:blur(18px)}
.rk-sidebar__inner{padding:22px}.rk-brand{display:flex;align-items:center;gap:13px;margin-bottom:28px}
.rk-brand__logo{width:42px;filter:brightness(0) invert(1) drop-shadow(0 0 18px rgba(247,209,0,.28))}
.rk-brand__en{margin:0;font-size:13px;line-height:1;font-weight:700;letter-spacing:.12em}.rk-brand__kr{margin:6px 0 0;color:var(--rk-muted);font-size:12px;line-height:1}
.rk-nav{display:flex;flex-direction:column;gap:7px}.rk-nav__link{display:flex;align-items:center;gap:11px;min-height:42px;padding:0 12px;border:1px solid transparent;border-radius:14px;color:var(--rk-muted);font-weight:700;transition:.16s}
.rk-nav__link:hover,.rk-nav__link.is-active{border-color:rgba(247,209,0,.18);background:var(--rk-yellow-soft);color:var(--rk-text)}
.rk-shell{min-width:0}.rk-topbar{position:sticky;top:0;z-index:20;min-height:var(--rk-topbar);border-bottom:1px solid var(--rk-line);background:rgba(5,7,10,.66);backdrop-filter:blur(18px)}
.rk-topbar__inner{display:flex;align-items:center;justify-content:space-between;gap:18px;min-height:var(--rk-topbar);padding:0 28px}.rk-content{max-width:1560px;margin:0 auto;padding:28px}
.rk-page-title{margin:0;font-family:var(--rk-font-title);font-size:25px;line-height:1.1;letter-spacing:-.045em}.rk-page-desc{margin:5px 0 0;color:var(--rk-dim);font-size:13px}
.rk-stack{display:flex;flex-direction:column;gap:20px}.rk-grid{display:grid;gap:16px}.rk-grid-2{grid-template-columns:repeat(2,minmax(0,1fr))}.rk-grid-3{grid-template-columns:repeat(3,minmax(0,1fr))}.rk-grid-4{grid-template-columns:repeat(4,minmax(0,1fr))}
.rk-layout-main-side{display:grid;grid-template-columns:minmax(0,1fr) 360px;gap:20px}.rk-side-sticky{position:sticky;top:calc(var(--rk-topbar) + 20px);align-self:start}
.rk-section{scroll-margin-top:calc(var(--rk-topbar) + 24px)}.rk-section+.rk-section{margin-top:28px}.rk-section-head{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;margin-bottom:14px}
.rk-section-title{margin:0;font-family:var(--rk-font-title);font-size:20px;line-height:1.2;letter-spacing:-.035em}.rk-section-desc{margin:5px 0 0;color:var(--rk-dim);font-size:13px}

.rk-card{position:relative;overflow:hidden;border:1px solid var(--rk-line);border-radius:var(--rk-radius-lg);background:linear-gradient(180deg,rgba(255,255,255,.062),rgba(255,255,255,.03)),var(--rk-panel-glass);box-shadow:0 10px 26px rgba(0,0,0,.26)}
.rk-card:before{content:"";position:absolute;inset:0;pointer-events:none;background:linear-gradient(135deg,rgba(247,209,0,.075),transparent 18%,transparent 80%,rgba(255,255,255,.035));opacity:.7}.rk-card>*{position:relative;z-index:1}
.rk-card__body{padding:20px}.rk-card__head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:16px}.rk-card__title{margin:0;font-size:17px;font-weight:700;letter-spacing:-.025em}.rk-card__desc{margin:5px 0 0;color:var(--rk-dim);font-size:13px}
.rk-card__icon{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;border:1px solid rgba(247,209,0,.18);border-radius:14px;background:var(--rk-yellow-soft);color:var(--rk-yellow)}
.rk-card--accent{border-color:rgba(247,209,0,.24)}.rk-card--flat{box-shadow:none}

.rk-hero{position:relative;overflow:hidden;min-height:320px;border:1px solid var(--rk-line);border-radius:var(--rk-radius-xl);background:radial-gradient(circle at 74% 42%,rgba(247,209,0,.16),transparent 28%),linear-gradient(145deg,#161d27 0%,#070a0f 100%);box-shadow:0 20px 52px rgba(0,0,0,.34)}
.rk-hero__body{position:relative;z-index:3;display:grid;grid-template-columns:minmax(0,1fr) 240px;gap:24px;align-items:center;padding:34px;min-height:inherit}.rk-hero__title{margin:0;font-family:var(--rk-font-title);font-size:clamp(34px,5vw,60px);line-height:.98;letter-spacing:-.06em}.rk-hero__title span{color:var(--rk-yellow)}
.rk-hero__desc{max-width:650px;margin:18px 0 0;color:var(--rk-muted);font-size:15px;line-height:1.7}.rk-hero__logo{justify-self:center;width:120px;filter:brightness(0) invert(1) drop-shadow(0 0 28px rgba(247,209,0,.34))}
.rk-light-sweep{position:absolute;inset:-8%;z-index:1;pointer-events:none;overflow:hidden}.rk-light-sweep:before,.rk-light-sweep:after{content:"";position:absolute;right:-60%;top:44%;width:132%;height:2px;background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.05) 18%,rgba(247,209,0,.72) 46%,rgba(255,255,255,.34) 52%,rgba(247,209,0,.24) 62%,transparent 100%);filter:blur(.2px) drop-shadow(0 0 14px rgba(247,209,0,.52)) drop-shadow(0 0 36px rgba(247,209,0,.24));animation:rkMainLightSweep 6.4s var(--rk-ease) infinite;opacity:0}.rk-light-sweep:after{top:51%;height:1px;animation-delay:.16s;filter:blur(.8px) drop-shadow(0 0 24px rgba(247,209,0,.2))}

.rk-palette{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:12px}.rk-swatch{min-height:110px;border:1px solid var(--rk-line);border-radius:18px;padding:14px;background:var(--rk-panel)}.rk-swatch__color{height:42px;border-radius:12px;margin-bottom:12px;border:1px solid rgba(255,255,255,.12)}.rk-swatch__name{font-weight:700}.rk-swatch__code{margin-top:4px;color:var(--rk-dim);font-size:12px}
.rk-font-title{font-family:var(--rk-font-title)}.rk-display{margin:0;font-family:var(--rk-font-title);font-size:44px;line-height:1;letter-spacing:-.06em}.rk-h1{margin:0;font-size:32px;line-height:1.12;letter-spacing:-.045em}.rk-h2{margin:0;font-size:24px;line-height:1.18;letter-spacing:-.035em}.rk-h3{margin:0;font-size:18px;line-height:1.28;letter-spacing:-.025em}.rk-p{margin:0;color:var(--rk-muted);line-height:1.7}

.rk-actions{display:flex;flex-wrap:wrap;gap:9px}.rk-btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;height:40px;padding:0 14px;border:1px solid var(--rk-line);border-radius:12px;background:rgba(255,255,255,.045);color:var(--rk-text);font-size:13px;font-weight:700;text-decoration:none;transition:.16s}
.rk-btn:hover{transform:translateY(-1px);border-color:var(--rk-line-2);background:var(--rk-soft-2);box-shadow:0 10px 26px rgba(0,0,0,.26)}.rk-btn:disabled,.rk-btn.is-disabled{opacity:.48;cursor:not-allowed;transform:none;box-shadow:none}
.rk-btn--primary{border-color:transparent;background:linear-gradient(135deg,var(--rk-yellow) 0%,var(--rk-yellow-2) 100%);color:#101010;box-shadow:var(--rk-shadow-yellow)}.rk-btn--danger{border-color:rgba(255,92,92,.22);background:var(--rk-red-soft);color:var(--rk-red)}.rk-btn--success{border-color:rgba(50,213,131,.22);background:var(--rk-green-soft);color:var(--rk-green)}.rk-btn--ghost{background:transparent}.rk-btn--sm{height:34px;padding:0 11px;border-radius:10px;font-size:12px}.rk-btn--lg{height:50px;padding:0 20px;border-radius:15px;font-size:15px}

.rk-form{display:grid;gap:16px}.rk-field label{display:block;margin-bottom:7px;color:var(--rk-muted);font-size:13px;font-weight:700}.rk-required{color:var(--rk-yellow);margin-left:4px}.rk-helper{margin:7px 0 0;color:var(--rk-dim);font-size:12px}
.rk-input,.rk-select,.rk-textarea{display:block;width:100%;border:1px solid var(--rk-line);border-radius:var(--rk-radius-md);outline:none;background:var(--rk-soft);color:var(--rk-text);transition:.18s}.rk-input,.rk-select{height:44px;padding:0 13px}.rk-textarea{min-height:108px;padding:13px;resize:vertical;line-height:1.65}.rk-input::placeholder,.rk-textarea::placeholder{color:rgba(247,248,250,.32)}.rk-input:focus,.rk-select:focus,.rk-textarea:focus{border-color:rgba(247,209,0,.72);background:rgba(255,255,255,.064);box-shadow:0 0 0 4px rgba(247,209,0,.08)}
.rk-input[readonly],.rk-input:disabled,.rk-select:disabled,.rk-textarea:disabled{color:var(--rk-disabled);background:rgba(255,255,255,.026);cursor:not-allowed}.rk-input-wrap{position:relative}.rk-input-wrap .rk-input{padding-left:43px}.rk-input-icon{position:absolute;left:14px;top:50%;width:18px;height:18px;color:var(--rk-dim);transform:translateY(-50%);pointer-events:none}.rk-input-wrap:focus-within .rk-input-icon{color:var(--rk-yellow)}
.rk-check{display:inline-flex;align-items:center;gap:9px;color:var(--rk-muted);font-size:13px;font-weight:700;cursor:pointer}.rk-check input{appearance:none;position:relative;width:18px;height:18px;margin:0;border:1px solid var(--rk-line-2);border-radius:6px;background:rgba(255,255,255,.035)}.rk-check input:checked{border-color:var(--rk-yellow);background:var(--rk-yellow)}.rk-check input:checked:after{content:"";position:absolute;left:6px;top:3px;width:4px;height:8px;border-right:2px solid #111;border-bottom:2px solid #111;transform:rotate(45deg)}.rk-radio input{border-radius:999px}.rk-radio input:checked:after{left:5px;top:5px;width:6px;height:6px;border:0;border-radius:999px;background:#111;transform:none}

.rk-badge{display:inline-flex;align-items:center;gap:6px;min-height:26px;padding:3px 10px;border:1px solid var(--rk-line);border-radius:999px;background:rgba(255,255,255,.045);color:var(--rk-muted);font-size:12px;font-weight:700;white-space:nowrap}.rk-badge:before{content:"";width:6px;height:6px;border-radius:999px;background:currentColor;opacity:.84}.rk-badge--yellow{border-color:rgba(247,209,0,.22);background:var(--rk-yellow-soft);color:var(--rk-yellow)}.rk-badge--green{border-color:rgba(50,213,131,.22);background:var(--rk-green-soft);color:var(--rk-green)}.rk-badge--blue{border-color:rgba(104,167,255,.22);background:var(--rk-blue-soft);color:var(--rk-blue)}.rk-badge--red{border-color:rgba(255,92,92,.22);background:var(--rk-red-soft);color:var(--rk-red)}.rk-badge--orange{border-color:rgba(255,176,32,.22);background:var(--rk-orange-soft);color:var(--rk-orange)}.rk-badge--purple{border-color:rgba(167,139,250,.22);background:var(--rk-purple-soft);color:var(--rk-purple)}

.rk-stat{padding:18px;border:1px solid var(--rk-line);border-radius:var(--rk-radius-lg);background:var(--rk-panel-glass);box-shadow:0 10px 26px rgba(0,0,0,.26)}.rk-stat__label{color:var(--rk-dim);font-size:12px;font-weight:700}.rk-stat__value{margin-top:10px;font-family:var(--rk-font-title);font-size:30px;line-height:1;letter-spacing:-.05em}.rk-stat__desc{margin-top:7px;color:var(--rk-dim);font-size:12px}

.rk-table-wrap{overflow:auto;border:1px solid var(--rk-line);border-radius:var(--rk-radius-lg);background:rgba(5,7,10,.28)}.rk-table{width:100%;min-width:860px;border-collapse:collapse}.rk-table th,.rk-table td{height:48px;padding:10px 13px;border-bottom:1px solid var(--rk-line);text-align:left;vertical-align:middle}.rk-table th{position:sticky;top:0;z-index:1;background:#111720;color:var(--rk-muted);font-size:12px;font-weight:700}.rk-table tr:hover td{background:rgba(255,255,255,.035)}.rk-table tr:last-child td{border-bottom:0}.rk-number{text-align:right;font-variant-numeric:tabular-nums}.rk-center{text-align:center}

.rk-tabs{display:flex;gap:7px;padding:5px;border:1px solid var(--rk-line);border-radius:15px;background:rgba(255,255,255,.034)}.rk-tab{height:36px;padding:0 13px;border:0;border-radius:11px;background:transparent;color:var(--rk-muted);font-weight:700}.rk-tab.is-active{background:var(--rk-yellow);color:#101010}
.rk-alert{display:flex;align-items:flex-start;gap:12px;border:1px solid var(--rk-line);border-radius:var(--rk-radius-md);padding:14px;background:rgba(255,255,255,.045)}.rk-alert__icon{display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;border-radius:10px;background:var(--rk-yellow-soft);color:var(--rk-yellow);font-weight:700}.rk-alert__title{margin:0;font-weight:700}.rk-alert__desc{margin:4px 0 0;color:var(--rk-dim);font-size:13px}.rk-alert--danger .rk-alert__icon{background:var(--rk-red-soft);color:var(--rk-red)}.rk-alert--success .rk-alert__icon{background:var(--rk-green-soft);color:var(--rk-green)}
.rk-progress{overflow:hidden;height:8px;border-radius:999px;background:rgba(255,255,255,.08)}.rk-progress__bar{height:100%;border-radius:inherit;background:linear-gradient(90deg,var(--rk-yellow),var(--rk-yellow-2));box-shadow:0 0 18px rgba(247,209,0,.36)}
.rk-stepper{display:flex;gap:8px}.rk-step{flex:1;min-width:0;padding:13px;border:1px solid var(--rk-line);border-radius:14px;background:rgba(255,255,255,.035)}.rk-step.is-active{border-color:rgba(247,209,0,.32);background:var(--rk-yellow-soft)}.rk-step__num{color:var(--rk-yellow);font-weight:700}.rk-step__text{margin-top:5px;font-size:13px;font-weight:700}
.rk-dropzone{min-height:150px;display:flex;align-items:center;justify-content:center;border:1px dashed var(--rk-line-2);border-radius:var(--rk-radius-lg);background:rgba(255,255,255,.032);text-align:center;padding:20px}.rk-dropzone__title{margin:10px 0 4px;font-weight:700}.rk-dropzone__desc{margin:0;color:var(--rk-dim);font-size:12px}
.rk-list{display:flex;flex-direction:column;gap:10px}.rk-list-item{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:13px;border:1px solid var(--rk-line);border-radius:15px;background:rgba(255,255,255,.035)}.rk-list-item__title{font-weight:700}.rk-list-item__desc{margin-top:4px;color:var(--rk-dim);font-size:12px}
.rk-timeline{display:flex;flex-direction:column;gap:12px}.rk-timeline-item{position:relative;padding-left:28px}.rk-timeline-item:before{content:"";position:absolute;left:7px;top:8px;width:9px;height:9px;border-radius:999px;background:var(--rk-yellow);box-shadow:0 0 18px rgba(247,209,0,.46)}.rk-timeline-item:after{content:"";position:absolute;left:11px;top:20px;bottom:-16px;width:1px;background:var(--rk-line)}.rk-timeline-item:last-child:after{display:none}
.rk-pagination{display:flex;align-items:center;justify-content:center;gap:6px}.rk-page-btn{min-width:34px;height:34px;border:1px solid var(--rk-line);border-radius:10px;background:rgba(255,255,255,.04);color:var(--rk-muted);font-weight:700}.rk-page-btn.is-active{border-color:var(--rk-yellow);background:var(--rk-yellow);color:#101010}
.rk-empty{min-height:220px;display:flex;align-items:center;justify-content:center;border:1px dashed var(--rk-line-2);border-radius:var(--rk-radius-lg);background:rgba(255,255,255,.028);text-align:center;padding:24px}.rk-empty__icon{width:54px;height:54px;margin:0 auto 14px;display:flex;align-items:center;justify-content:center;border-radius:18px;background:var(--rk-yellow-soft);color:var(--rk-yellow)}

.rk-modal-backdrop{position:fixed;inset:0;z-index:60;display:none;align-items:center;justify-content:center;padding:24px;background:rgba(5,7,10,.72);backdrop-filter:blur(16px)}.rk-modal-backdrop.is-visible{display:flex;animation:rkFadeIn .18s ease both}.rk-modal{width:min(100%,560px);border:1px solid var(--rk-line);border-radius:24px;background:linear-gradient(180deg,rgba(255,255,255,.072),rgba(255,255,255,.036)),var(--rk-panel-2);box-shadow:var(--rk-shadow-lg)}.rk-modal__head,.rk-modal__body,.rk-modal__foot{padding:18px}.rk-modal__head{display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--rk-line)}.rk-modal__title{margin:0;font-size:18px;font-weight:700}.rk-modal__foot{display:flex;justify-content:flex-end;gap:8px;border-top:1px solid var(--rk-line)}
.rk-toast{position:fixed;right:24px;bottom:24px;z-index:80;display:none;max-width:360px;padding:14px 16px;border:1px solid rgba(247,209,0,.22);border-radius:18px;background:rgba(15,19,26,.96);color:var(--rk-text);box-shadow:0 20px 52px rgba(0,0,0,.34);backdrop-filter:blur(16px);font-weight:700}.rk-toast.is-visible{display:block;animation:rkToastIn .2s ease both}

.rk-login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:28px}.rk-login-wrap{width:min(980px,100%);min-height:612px;display:grid;grid-template-columns:.92fr 1.08fr;overflow:hidden;border:1px solid var(--rk-line);border-radius:var(--rk-radius-xl);background:linear-gradient(180deg,rgba(255,255,255,.07),rgba(255,255,255,.026)),var(--rk-panel-glass);box-shadow:var(--rk-shadow-lg)}.rk-login-form-side{display:flex;align-items:center;justify-content:center;padding:54px 46px;border-right:1px solid var(--rk-line);background:rgba(5,7,10,.48)}.rk-login-form-box{width:100%;max-width:356px}.rk-system-lockup{margin-bottom:34px}.rk-system-lockup__en{margin:0;color:var(--rk-yellow);font-size:13px;line-height:1;font-weight:700;letter-spacing:.16em}.rk-system-lockup__kr{margin:10px 0 0;color:var(--rk-text);font-size:24px;line-height:1;font-weight:700;letter-spacing:-.035em}.rk-system-lockup__line{display:block;width:48px;height:2px;margin-top:18px;border-radius:999px;background:var(--rk-yellow);box-shadow:0 0 18px rgba(247,209,0,.44)}.rk-login-brand-side{position:relative;display:flex;align-items:center;justify-content:center;overflow:hidden;background:radial-gradient(circle at 50% 46%,rgba(247,209,0,.14),transparent 31%),linear-gradient(145deg,#151b24 0%,#070a0f 100%)}.rk-login-logo{position:relative;z-index:3;width:118px;filter:brightness(0) invert(1) drop-shadow(0 0 10px rgba(255,255,255,.12)) drop-shadow(0 0 24px rgba(247,209,0,.28))}
.rk-muted{color:var(--rk-dim)}.rk-text-soft{color:var(--rk-muted)}.rk-text-yellow{color:var(--rk-yellow)}.rk-mt-8{margin-top:8px}.rk-mt-12{margin-top:12px}.rk-mt-16{margin-top:16px}.rk-mt-20{margin-top:20px}.rk-hidden{display:none!important}

@keyframes rkMainLightSweep{0%{transform:translateX(0) skewX(-12deg);opacity:0}12%{opacity:.84}52%{opacity:.58}100%{transform:translateX(-118%) skewX(-12deg);opacity:0}}
@keyframes rkFadeIn{from{opacity:0}to{opacity:1}}@keyframes rkToastIn{from{transform:translateY(12px);opacity:0}to{transform:translateY(0);opacity:1}}

@media (prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}
@media (max-width:1180px){.rk-app{grid-template-columns:1fr}.rk-sidebar{position:static;height:auto}.rk-sidebar__inner{padding:16px}.rk-nav{flex-direction:row;overflow:auto}.rk-nav__link{white-space:nowrap}.rk-layout-main-side{grid-template-columns:1fr}.rk-side-sticky{position:static}.rk-grid-4{grid-template-columns:repeat(2,minmax(0,1fr))}.rk-palette{grid-template-columns:repeat(3,minmax(0,1fr))}}
@media (max-width:760px){body{font-size:13px}.rk-topbar__inner{align-items:flex-start;flex-direction:column;padding:16px}.rk-content{padding:16px}.rk-grid-2,.rk-grid-3,.rk-grid-4,.rk-palette,.rk-hero__body,.rk-login-wrap{grid-template-columns:1fr}.rk-login-brand-side{display:none}.rk-login-form-side{border-right:0;padding:34px 24px}.rk-hero__logo{display:none}.rk-display{font-size:34px}.rk-page-title{font-size:22px}.rk-table{min-width:720px}}
@media print{body{background:#fff!important;color:#000}.rk-sidebar,.rk-topbar,.rk-actions,.rk-toast{display:none!important}.rk-app{display:block}.rk-content{max-width:none;padding:0}.rk-card{box-shadow:none;border-color:#222;background:#fff;color:#000}}


/*
  BY JS 2026-06-05
  르노코리아 다크 디자인 스켈레톤 V2 보완
  - 리퀴드 글라스 질감 강화
  - 애플식 부드러운 전환
  - 네이티브 select / 커스텀 드롭다운 다크 스타일
  - Tabulator 업무용 데이터그리드 스타일
  - 컴팩트 검색/요약/모달/토스트 개선
*/
:root{
  --rk-glass-bg:rgba(18,24,34,.58);
  --rk-glass-bg-strong:rgba(19,25,35,.78);
  --rk-glass-line:rgba(255,255,255,.14);
  --rk-glass-top:rgba(255,255,255,.18);
  --rk-blur:24px;
  --rk-blur-strong:36px;
  --rk-duration-fast:.18s;
  --rk-duration:.32s;
  --rk-duration-slow:.58s;
  --rk-ease-apple:cubic-bezier(.16,1,.3,1);
  --rk-ease-soft:cubic-bezier(.2,.8,.2,1);
}
body{background-attachment:fixed;}
.rk-card,.rk-stat,.rk-modal,.rk-toast,.rk-table-wrap,.rk-search-panel,.rk-filter-drawer,.rk-mini-summary,.rk-glass-panel{
  background:linear-gradient(180deg,rgba(255,255,255,.105),rgba(255,255,255,.035)),var(--rk-glass-bg)!important;
  border-color:var(--rk-glass-line)!important;
  box-shadow:0 18px 54px rgba(0,0,0,.28),inset 0 1px 0 var(--rk-glass-top)!important;
  backdrop-filter:blur(var(--rk-blur)) saturate(1.34)!important;
  -webkit-backdrop-filter:blur(var(--rk-blur)) saturate(1.34)!important;
}
.rk-card{border-radius:20px;transition:transform var(--rk-duration) var(--rk-ease-apple),border-color var(--rk-duration) var(--rk-ease-apple),box-shadow var(--rk-duration) var(--rk-ease-apple),background-color var(--rk-duration) var(--rk-ease-apple)}
.rk-card:hover{border-color:rgba(247,209,0,.2)!important;box-shadow:0 22px 62px rgba(0,0,0,.32),inset 0 1px 0 rgba(255,255,255,.2)!important}
.rk-card__body{padding:18px}.rk-card__head{margin-bottom:13px}.rk-section+.rk-section{margin-top:20px}.rk-content{padding:22px}.rk-section-head{margin-bottom:12px}.rk-page-title{font-size:23px}.rk-page-desc,.rk-section-desc,.rk-card__desc{font-size:12px}
.rk-btn{transition:transform var(--rk-duration-fast) var(--rk-ease-apple),box-shadow var(--rk-duration) var(--rk-ease-apple),background var(--rk-duration) var(--rk-ease-apple),border-color var(--rk-duration) var(--rk-ease-apple),color var(--rk-duration) var(--rk-ease-apple);will-change:transform}
.rk-btn:hover{transform:translateY(-1px) scale(1.012)}
.rk-btn--primary{background:linear-gradient(135deg,#f7d100 0%,#ffe983 100%)!important;color:#0b0d11!important;text-shadow:none;box-shadow:0 14px 34px rgba(247,209,0,.18),inset 0 1px 0 rgba(255,255,255,.64)!important}
.rk-btn--primary:hover{background:linear-gradient(135deg,#ffe066 0%,#fff0a8 100%)!important;color:#08090b!important;box-shadow:0 18px 44px rgba(247,209,0,.26),inset 0 1px 0 rgba(255,255,255,.76)!important;filter:saturate(1.03)}
.rk-btn--primary:active{transform:translateY(0) scale(.992)}
.rk-input,.rk-select,.rk-textarea{background:rgba(255,255,255,.048)!important;border-color:rgba(255,255,255,.13)!important;box-shadow:inset 0 1px 0 rgba(255,255,255,.06);transition:border-color var(--rk-duration) var(--rk-ease-apple),box-shadow var(--rk-duration) var(--rk-ease-apple),background var(--rk-duration) var(--rk-ease-apple),transform var(--rk-duration) var(--rk-ease-apple)}
.rk-input:focus,.rk-select:focus,.rk-textarea:focus{border-color:rgba(247,209,0,.76)!important;background:rgba(255,255,255,.074)!important;box-shadow:0 0 0 4px rgba(247,209,0,.075),inset 0 1px 0 rgba(255,255,255,.11)!important;transform:translateY(-1px)}
.rk-select{appearance:none;-webkit-appearance:none;padding-right:42px;background-image:linear-gradient(45deg,transparent 50%,var(--rk-yellow) 50%),linear-gradient(135deg,var(--rk-yellow) 50%,transparent 50%)!important;background-position:calc(100% - 20px) 19px,calc(100% - 14px) 19px!important;background-size:6px 6px,6px 6px!important;background-repeat:no-repeat!important;color:var(--rk-text)!important}
.rk-select option{background:#111720;color:#f7f8fa}.rk-select option:checked{background:#2a2610;color:#f7d100}.rk-select option:hover{background:#1d2532;color:#fff}
.rk-select-wrap{position:relative}.rk-select-wrap:after{content:"";position:absolute;right:12px;top:50%;width:24px;height:24px;border-radius:9px;background:rgba(247,209,0,.08);transform:translateY(-50%);pointer-events:none;z-index:-1}
.rk-select-menu{position:relative}.rk-select-button{display:flex;align-items:center;justify-content:space-between;width:100%;height:44px;padding:0 13px;border:1px solid rgba(255,255,255,.13);border-radius:var(--rk-radius-md);background:rgba(255,255,255,.048);color:var(--rk-text);font-weight:700}.rk-select-list{display:none;position:absolute;left:0;right:0;top:calc(100% + 8px);z-index:30;padding:7px;border:1px solid rgba(255,255,255,.14);border-radius:16px;background:rgba(17,23,32,.94);box-shadow:0 24px 52px rgba(0,0,0,.38);backdrop-filter:blur(24px) saturate(1.3)}.rk-select-menu.is-open .rk-select-list{display:block;animation:rkDropdownIn .24s var(--rk-ease-apple) both}.rk-select-option{display:flex;align-items:center;justify-content:space-between;width:100%;min-height:36px;padding:0 10px;border:0;border-radius:11px;background:transparent;color:var(--rk-text-soft);font-weight:700;text-align:left}.rk-select-option:hover,.rk-select-option.is-selected{background:rgba(247,209,0,.12);color:var(--rk-yellow)}
.rk-badge{min-height:24px;padding:3px 9px;border-radius:999px;background:linear-gradient(180deg,rgba(255,255,255,.07),rgba(255,255,255,.028));box-shadow:inset 0 1px 0 rgba(255,255,255,.12);letter-spacing:-.01em}.rk-badge:before{width:5px;height:5px;box-shadow:0 0 12px currentColor}.rk-badge--yellow{background:linear-gradient(180deg,rgba(247,209,0,.16),rgba(247,209,0,.055));border-color:rgba(247,209,0,.32)}.rk-badge--green{background:linear-gradient(180deg,rgba(50,213,131,.16),rgba(50,213,131,.055));border-color:rgba(50,213,131,.3)}.rk-badge--blue{background:linear-gradient(180deg,rgba(104,167,255,.16),rgba(104,167,255,.055));border-color:rgba(104,167,255,.3)}.rk-badge--red{background:linear-gradient(180deg,rgba(255,92,92,.16),rgba(255,92,92,.055));border-color:rgba(255,92,92,.3)}.rk-badge--orange{background:linear-gradient(180deg,rgba(255,176,32,.16),rgba(255,176,32,.055));border-color:rgba(255,176,32,.3)}
.rk-tabs{position:relative;padding:4px;border-radius:14px;overflow:hidden}.rk-tab{position:relative;z-index:2;transition:color var(--rk-duration) var(--rk-ease-apple),transform var(--rk-duration) var(--rk-ease-apple)}.rk-tab:hover{transform:translateY(-1px)}.rk-tab.is-active{background:transparent!important;color:#101010!important}.rk-tab-indicator{position:absolute;z-index:1;top:4px;bottom:4px;left:4px;width:calc((100% - 8px)/3);border-radius:11px;background:linear-gradient(135deg,var(--rk-yellow),var(--rk-yellow-2));box-shadow:0 10px 24px rgba(247,209,0,.18);transition:transform var(--rk-duration-slow) var(--rk-ease-apple)}.rk-tabs[data-active="1"] .rk-tab-indicator{transform:translateX(0)}.rk-tabs[data-active="2"] .rk-tab-indicator{transform:translateX(100%)}.rk-tabs[data-active="3"] .rk-tab-indicator{transform:translateX(200%)}
.rk-timeline{gap:10px}.rk-timeline-item{padding:11px 11px 11px 30px;border:1px solid transparent;border-radius:14px;transition:background var(--rk-duration) var(--rk-ease-apple),border-color var(--rk-duration) var(--rk-ease-apple),transform var(--rk-duration) var(--rk-ease-apple)}.rk-timeline-item.is-current{border-color:rgba(247,209,0,.24);background:rgba(247,209,0,.08);box-shadow:inset 0 1px 0 rgba(255,255,255,.08)}.rk-timeline-item.is-current:before{width:11px;height:11px;background:var(--rk-yellow);box-shadow:0 0 18px rgba(247,209,0,.74)}
.rk-modal-backdrop{background:rgba(3,5,8,.58)!important;backdrop-filter:blur(28px) saturate(1.25)}.rk-modal{width:min(100%,460px)!important;border-radius:22px!important;transform:translateY(8px) scale(.985);animation:rkModalIn .3s var(--rk-ease-apple) forwards}.rk-modal__head,.rk-modal__body,.rk-modal__foot{padding:16px!important}.rk-modal__title{font-size:17px}.rk-modal__body .rk-p{font-size:13px}.rk-modal__foot{gap:7px}
.rk-toast{right:22px;bottom:22px;max-width:320px;padding:12px 14px 12px 40px!important;border-radius:16px!important;font-size:13px!important;font-weight:700!important;color:var(--rk-text-soft)!important}.rk-toast:before{content:"";position:absolute;left:15px;top:50%;width:8px;height:8px;border-radius:999px;background:var(--rk-yellow);box-shadow:0 0 14px rgba(247,209,0,.56);transform:translateY(-50%)}
.rk-mini-summary{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;padding:10px;border-radius:18px}.rk-mini-stat{min-width:0;padding:12px;border:1px solid rgba(255,255,255,.1);border-radius:15px;background:rgba(255,255,255,.035)}.rk-mini-stat__label{color:var(--rk-text-muted);font-size:11px;font-weight:700}.rk-mini-stat__value{margin-top:5px;font-family:var(--rk-font-title);font-size:21px;line-height:1;letter-spacing:-.045em}.rk-mini-stat__value small{font-size:12px;color:var(--rk-text-muted);font-family:var(--rk-font);font-weight:700;margin-left:2px}
.rk-search-panel{padding:12px;border-radius:18px}.rk-search-line{display:grid;grid-template-columns:minmax(260px,1fr) auto auto;gap:8px;align-items:center}.rk-filter-drawer{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;margin-top:10px;padding:12px;border-radius:16px;max-height:0;overflow:hidden;opacity:0;transform:translateY(-4px);transition:max-height var(--rk-duration-slow) var(--rk-ease-apple),opacity var(--rk-duration) var(--rk-ease-apple),transform var(--rk-duration) var(--rk-ease-apple),padding var(--rk-duration) var(--rk-ease-apple),margin var(--rk-duration) var(--rk-ease-apple)}.rk-filter-drawer.is-open{max-height:160px;opacity:1;transform:translateY(0)}
.rk-unit-field{position:relative}.rk-unit-field .rk-input{padding-right:48px}.rk-unit{position:absolute;right:13px;top:50%;transform:translateY(-50%);color:var(--rk-text-muted);font-size:12px;font-weight:700;pointer-events:none}.rk-money,.rk-qty{text-align:right;font-variant-numeric:tabular-nums}
.rk-table-toolbar{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:10px}.rk-table-toolbar__meta{color:var(--rk-text-muted);font-size:12px}.rk-table-wrap{border-radius:18px}.rk-table th,.rk-table td{height:40px!important;padding:7px 10px!important}.rk-table th{background:rgba(17,23,32,.92)!important}.rk-table tr:nth-child(even) td{background:rgba(255,255,255,.018)}
.rk-tabulator{height:520px;border:1px solid var(--rk-line)!important;border-radius:18px!important;background:rgba(5,7,10,.3)!important;overflow:hidden;box-shadow:inset 0 1px 0 rgba(255,255,255,.06)}.rk-tabulator .tabulator{border:0!important;background:transparent!important;color:var(--rk-text)!important;font-family:var(--rk-font)!important}.rk-tabulator .tabulator-header{border-bottom:1px solid rgba(255,255,255,.12)!important;background:rgba(17,23,32,.94)!important;color:var(--rk-text-soft)!important}.rk-tabulator .tabulator-col{background:rgba(17,23,32,.94)!important;border-right:1px solid rgba(255,255,255,.08)!important}.rk-tabulator .tabulator-col-title{font-size:12px;font-weight:800;letter-spacing:-.01em}.rk-tabulator .tabulator-row{min-height:38px!important;background:rgba(255,255,255,.012)!important;border-bottom:1px solid rgba(255,255,255,.065)!important;color:var(--rk-text)!important}.rk-tabulator .tabulator-row:nth-child(even){background:rgba(255,255,255,.032)!important}.rk-tabulator .tabulator-row:hover{background:rgba(247,209,0,.075)!important}.rk-tabulator .tabulator-cell{padding:8px 10px!important;border-right:1px solid rgba(255,255,255,.055)!important;font-size:13px;line-height:1.35}.rk-tabulator .tabulator-footer{background:rgba(17,23,32,.95)!important;border-top:1px solid rgba(255,255,255,.12)!important;color:var(--rk-text-soft)!important}.rk-tabulator .tabulator-page{border:1px solid rgba(255,255,255,.12)!important;border-radius:9px!important;background:rgba(255,255,255,.045)!important;color:var(--rk-text-soft)!important}.rk-tabulator .tabulator-page.active{background:var(--rk-yellow)!important;color:#101010!important;border-color:transparent!important}.rk-tabulator .tabulator-placeholder{color:var(--rk-text-muted)!important}.rk-table-fallback{display:none}.rk-tabulator.is-fallback{height:auto}.rk-tabulator.is-fallback .rk-table-fallback{display:block}
.rk-heritage-line{height:1px;background:linear-gradient(90deg,transparent,rgba(247,209,0,.72),rgba(255,255,255,.18),transparent);filter:drop-shadow(0 0 14px rgba(247,209,0,.34));animation:rkMainLightSweep 7.2s var(--rk-ease-apple) infinite}.rk-brand-watermark{position:absolute;right:18px;bottom:18px;width:68px;opacity:.08;filter:brightness(0) invert(1);pointer-events:none}.rk-logo-chip{display:inline-flex;align-items:center;gap:9px;min-height:34px;padding:0 12px;border:1px solid rgba(247,209,0,.18);border-radius:999px;background:rgba(247,209,0,.07);color:var(--rk-text-soft);font-weight:700;font-size:12px}.rk-logo-chip img{width:18px;filter:brightness(0) invert(1) drop-shadow(0 0 10px rgba(247,209,0,.22))}
@keyframes rkDropdownIn{from{opacity:0;transform:translateY(-6px) scale(.985)}to{opacity:1;transform:translateY(0) scale(1)}}
@keyframes rkModalIn{to{transform:translateY(0) scale(1)}}
@media (max-width:1180px){.rk-filter-drawer{grid-template-columns:repeat(2,minmax(0,1fr))}.rk-mini-summary{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media (max-width:760px){.rk-search-line{grid-template-columns:1fr}.rk-filter-drawer,.rk-filter-drawer.is-open{grid-template-columns:1fr;max-height:420px}.rk-mini-summary{grid-template-columns:1fr}.rk-tabulator{height:460px}}



/*
  BY JS 2026-06-05 V3 보완
  - Apple 계열 리퀴드 글라스 질감 강화
  - Tabulator 루트 테마 직접 보정
  - 탭 인디케이터 실제 버튼 위치 기반 전환
  - 검색조건 밀도 개선
  - 모달/토스트 고급화
  - 타임라인 최신 항목 강조
*/

:root {
  --rk-ease-glass: cubic-bezier(0.16, 1, 0.3, 1);
  --rk-fast: 180ms;
  --rk-normal: 320ms;
  --rk-slow: 520ms;
  --rk-table-row: 36px;
}

/* 전체 글래스 질감 보정 */
.rk-card,
.rk-search-panel,
.rk-mini-summary,
.rk-modal,
.rk-toast,
.rk-table-wrap,
.rk-tabulator {
  background:
    linear-gradient(180deg, rgba(255,255,255,.086), rgba(255,255,255,.035)),
    rgba(13, 18, 25, .72) !important;
  border-color: rgba(255,255,255,.125) !important;
  box-shadow:
    0 24px 58px rgba(0,0,0,.31),
    inset 0 1px 0 rgba(255,255,255,.085) !important;
  backdrop-filter: blur(26px) saturate(1.28);
}

.rk-card:hover {
  border-color: rgba(255,255,255,.17) !important;
}

/* 버튼: 노란 버튼 hover 시 어두워지지 않게 보정 */
.rk-btn {
  transition:
    transform var(--rk-fast) var(--rk-ease-glass),
    border-color var(--rk-fast) var(--rk-ease-glass),
    background-color var(--rk-fast) var(--rk-ease-glass),
    box-shadow var(--rk-fast) var(--rk-ease-glass),
    color var(--rk-fast) var(--rk-ease-glass);
}

.rk-btn--primary {
  background: linear-gradient(135deg, #f7d100 0%, #ffe687 100%) !important;
  color: #070707 !important;
  text-shadow: 0 1px 0 rgba(255,255,255,.28);
}

.rk-btn--primary:hover {
  background: linear-gradient(135deg, #ffe066 0%, #fff2b8 100%) !important;
  color: #050505 !important;
  filter: none !important;
  box-shadow:
    0 18px 42px rgba(247,209,0,.23),
    inset 0 1px 0 rgba(255,255,255,.62) !important;
}

/* 폼/드롭다운 보정 */
.rk-select {
  background-color: rgba(255,255,255,.052) !important;
  color: var(--rk-text) !important;
}

.rk-select option {
  background: #0f151e !important;
  color: #f7f8fa !important;
}

.rk-select option:checked {
  background: #f7d100 !important;
  color: #111 !important;
}

.rk-select option:hover {
  background: #202838 !important;
  color: #fff !important;
}

.rk-select-menu {
  z-index: 35;
}

.rk-select-button {
  box-shadow: inset 0 1px 0 rgba(255,255,255,.07);
  transition:
    border-color var(--rk-normal) var(--rk-ease-glass),
    background-color var(--rk-normal) var(--rk-ease-glass),
    transform var(--rk-normal) var(--rk-ease-glass);
}

.rk-select-button:hover {
  border-color: rgba(247,209,0,.3);
  background: rgba(255,255,255,.066);
}

.rk-select-list {
  display: block !important;
  pointer-events: none;
  opacity: 0;
  transform: translateY(-8px) scale(.975);
  transform-origin: top center;
  transition:
    opacity var(--rk-normal) var(--rk-ease-glass),
    transform var(--rk-normal) var(--rk-ease-glass);
}

.rk-select-menu.is-open .rk-select-list {
  pointer-events: auto;
  opacity: 1;
  transform: translateY(0) scale(1);
  animation: none !important;
}

/* 탭: 실제 버튼 위치 기반 인디케이터 */
.rk-tabs {
  position: relative;
  gap: 0 !important;
  padding: 4px !important;
  overflow: hidden;
  border-radius: 16px;
}

.rk-tab {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  position: relative;
  z-index: 2;
  min-width: 84px;
  text-align: center;
  color: var(--rk-text-soft);
  transition:
    color var(--rk-normal) var(--rk-ease-glass),
    transform var(--rk-normal) var(--rk-ease-glass);
}

.rk-tab:hover {
  transform: none !important;
  color: var(--rk-text);
}

.rk-tab.is-active {
  background: transparent !important;
  color: #111 !important;
}

.rk-tab-indicator {
  position: absolute;
  z-index: 1;
  top: 4px;
  bottom: 4px;
  left: 0;
  width: var(--rk-tab-w, 84px) !important;
  border-radius: 12px;
  background:
    linear-gradient(135deg, rgba(247,209,0,1), rgba(255,236,148,1));
  box-shadow:
    0 10px 28px rgba(247,209,0,.22),
    inset 0 1px 0 rgba(255,255,255,.5);
  transform: translateX(var(--rk-tab-x, 4px)) !important;
  transition:
    transform var(--rk-slow) var(--rk-ease-glass),
    width var(--rk-slow) var(--rk-ease-glass);
}

/* 상태 배지: 더 작고 고급스럽게 */
.rk-badge {
  min-height: 23px !important;
  padding: 2px 9px !important;
  border-radius: 999px;
  font-size: 11px !important;
  font-weight: 800;
  letter-spacing: .01em;
  background:
    linear-gradient(180deg, rgba(255,255,255,.09), rgba(255,255,255,.028)) !important;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.12),
    0 8px 20px rgba(0,0,0,.18);
}

.rk-badge::before {
  width: 5px !important;
  height: 5px !important;
  box-shadow: 0 0 12px currentColor;
}

.rk-badge--yellow { border-color: rgba(247,209,0,.34) !important; color: #f7d100; }
.rk-badge--green { border-color: rgba(50,213,131,.32) !important; color: #32d583; }
.rk-badge--blue { border-color: rgba(104,167,255,.32) !important; color: #68a7ff; }
.rk-badge--red { border-color: rgba(255,92,92,.32) !important; color: #ff6b6b; }
.rk-badge--orange { border-color: rgba(255,176,32,.32) !important; color: #ffbd45; }
.rk-badge--purple { border-color: rgba(167,139,250,.32) !important; color: #b8a2ff; }

/* 타임라인: 최신순/현재 항목 강조 */
.rk-timeline {
  gap: 8px !important;
}

.rk-timeline-item {
  padding: 12px 12px 12px 32px !important;
  border: 1px solid rgba(255,255,255,.08) !important;
  border-radius: 15px !important;
  background: rgba(255,255,255,.026);
}

.rk-timeline-item::after {
  bottom: -10px !important;
}

.rk-timeline-item.is-current {
  border-color: rgba(247,209,0,.32) !important;
  background:
    linear-gradient(180deg, rgba(247,209,0,.13), rgba(247,209,0,.045)) !important;
  box-shadow:
    0 16px 34px rgba(247,209,0,.08),
    inset 0 1px 0 rgba(255,255,255,.12) !important;
}

.rk-timeline-item.is-current strong {
  color: var(--rk-yellow);
}

/* 검색 조건: 기본 검색 + 날짜 노출, 상세 조건 압축 */
.rk-search-panel {
  padding: 10px !important;
  border-radius: 18px !important;
}

.rk-search-line {
  grid-template-columns: minmax(260px, 1fr) 152px 152px auto auto !important;
  gap: 8px !important;
}

.rk-filter-drawer {
  margin-top: 8px !important;
  padding: 0 2px !important;
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
  gap: 8px !important;
  background: transparent !important;
}

.rk-filter-drawer.is-open {
  max-height: 112px !important;
  padding: 8px 2px 2px !important;
}

/* 요약 카드 더 작게 */
.rk-mini-summary {
  gap: 8px !important;
  padding: 8px !important;
  border-radius: 16px !important;
}

.rk-mini-stat {
  min-height: 58px;
  padding: 9px 11px !important;
  border-radius: 13px !important;
}

.rk-mini-stat__label {
  font-size: 10px !important;
}

.rk-mini-stat__value {
  margin-top: 4px !important;
  font-size: 19px !important;
}

.rk-mini-stat__value small {
  font-size: 11px !important;
}

/* 테이블 카드 밀도 */
.rk-table-toolbar {
  min-height: 34px;
  margin-bottom: 8px !important;
}

.rk-table-toolbar .rk-card__title {
  font-size: 15px !important;
}

.rk-table-toolbar .rk-card__desc {
  display: none;
}

.rk-table-toolbar__meta {
  font-size: 11px !important;
}

/* Tabulator V3 다크 스킨: 루트가 .tabulator가 되므로 직접 선택 */
.rk-tabulator {
  height: calc(100vh - 292px) !important;
  min-height: 520px;
  border-radius: 18px !important;
  overflow: hidden !important;
  background: rgba(5,7,10,.38) !important;
}

.rk-tabulator.tabulator,
.rk-tabulator .tabulator {
  border: 0 !important;
  background: rgba(5,7,10,.38) !important;
  color: var(--rk-text) !important;
  font-family: var(--rk-font, "Happiness Sans", "Noto Sans KR", sans-serif) !important;
}

.rk-tabulator .tabulator-header,
.rk-tabulator.tabulator .tabulator-header {
  border-bottom: 1px solid rgba(255,255,255,.14) !important;
  background:
    linear-gradient(180deg, rgba(255,255,255,.07), rgba(255,255,255,.025)),
    #0e141d !important;
  color: var(--rk-text-soft) !important;
}

.rk-tabulator .tabulator-header .tabulator-col,
.rk-tabulator.tabulator .tabulator-header .tabulator-col {
  height: 36px !important;
  background: transparent !important;
  border-right: 1px solid rgba(255,255,255,.075) !important;
}

.rk-tabulator .tabulator-col-title {
  font-size: 11.5px !important;
  font-weight: 800 !important;
  letter-spacing: -.01em;
  line-height: 36px !important;
}

.rk-tabulator .tabulator-tableholder,
.rk-tabulator.tabulator .tabulator-tableholder {
  background: rgba(5,7,10,.26) !important;
}

.rk-tabulator .tabulator-table,
.rk-tabulator.tabulator .tabulator-table {
  background: transparent !important;
  color: var(--rk-text) !important;
}

.rk-tabulator .tabulator-row,
.rk-tabulator.tabulator .tabulator-row {
  min-height: var(--rk-table-row) !important;
  background: rgba(255,255,255,.018) !important;
  border-bottom: 1px solid rgba(255,255,255,.062) !important;
  color: var(--rk-text) !important;
  transition: background-color 140ms ease, box-shadow 140ms ease;
}

.rk-tabulator .tabulator-row:nth-child(even),
.rk-tabulator.tabulator .tabulator-row:nth-child(even) {
  background: rgba(255,255,255,.038) !important;
}

.rk-tabulator .tabulator-row:hover,
.rk-tabulator.tabulator .tabulator-row:hover {
  background: rgba(247,209,0,.082) !important;
  box-shadow: inset 2px 0 0 var(--rk-yellow);
}

.rk-tabulator .tabulator-row.tabulator-selected,
.rk-tabulator.tabulator .tabulator-row.tabulator-selected {
  background: rgba(247,209,0,.14) !important;
}

.rk-tabulator .tabulator-cell,
.rk-tabulator.tabulator .tabulator-cell {
  height: var(--rk-table-row) !important;
  padding: 7px 10px !important;
  border-right: 1px solid rgba(255,255,255,.052) !important;
  font-size: 12.5px !important;
  line-height: 22px !important;
  color: var(--rk-text) !important;
}

.rk-tabulator .tabulator-cell:last-child {
  border-right: 0 !important;
}

.rk-tabulator .tabulator-footer,
.rk-tabulator.tabulator .tabulator-footer {
  min-height: 38px !important;
  border-top: 1px solid rgba(255,255,255,.14) !important;
  background:
    linear-gradient(180deg, rgba(255,255,255,.045), rgba(255,255,255,.018)),
    #0e141d !important;
  color: var(--rk-text-soft) !important;
}

.rk-tabulator .tabulator-calcs,
.rk-tabulator .tabulator-calcs-holder,
.rk-tabulator .tabulator-calcs-bottom {
  background: #111720 !important;
  color: var(--rk-text) !important;
}

.rk-tabulator .tabulator-page {
  min-width: 30px;
  height: 28px;
  margin: 0 2px !important;
  border: 1px solid rgba(255,255,255,.13) !important;
  border-radius: 9px !important;
  background: rgba(255,255,255,.05) !important;
  color: var(--rk-text-soft) !important;
  font-size: 12px !important;
}

.rk-tabulator .tabulator-page:hover {
  border-color: rgba(247,209,0,.32) !important;
  color: var(--rk-yellow) !important;
}

.rk-tabulator .tabulator-page.active {
  border-color: transparent !important;
  background: var(--rk-yellow) !important;
  color: #101010 !important;
}

.rk-tabulator .tabulator-placeholder {
  background: transparent !important;
  color: var(--rk-text-muted) !important;
}

.rk-tabulator .tabulator-loader {
  background: rgba(5,7,10,.7) !important;
}

/* 네이티브 테이블도 흰색 방지 */
.rk-table,
.rk-table tbody,
.rk-table tr,
.rk-table td {
  background-color: transparent !important;
  color: var(--rk-text) !important;
}

.rk-table-wrap {
  background: rgba(5,7,10,.38) !important;
}

.rk-table th {
  background: #0e141d !important;
}

.rk-table tr:nth-child(even) td {
  background: rgba(255,255,255,.025) !important;
}

/* 단위 필드 */
.rk-unit-field {
  position: relative;
}

.rk-unit-field .rk-input {
  padding-right: 54px !important;
}

.rk-unit {
  position: absolute;
  right: 13px;
  top: 50%;
  transform: translateY(-50%);
  color: var(--rk-text-muted);
  font-size: 12px;
  font-weight: 800;
  pointer-events: none;
}

/* 모달: 작고 현대적으로 */
.rk-modal-backdrop {
  background:
    radial-gradient(circle at 50% 42%, rgba(247,209,0,.12), transparent 30%),
    rgba(3,5,8,.62) !important;
  backdrop-filter: blur(32px) saturate(1.32) !important;
}

.rk-modal {
  width: min(100%, 430px) !important;
  overflow: hidden;
  border-radius: 24px !important;
  transform: translateY(12px) scale(.97);
  animation: rkModalInV3 var(--rk-normal) var(--rk-ease-glass) forwards !important;
}

.rk-modal::before {
  content: "";
  position: absolute;
  left: 18px;
  right: 18px;
  top: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(247,209,0,.78), transparent);
  filter: drop-shadow(0 0 12px rgba(247,209,0,.38));
}

.rk-modal::after {
  content: "";
  position: absolute;
  right: 18px;
  bottom: 18px;
  width: 70px;
  height: 70px;
  background: url("../img/logo.svg") center/contain no-repeat;
  opacity: .055;
  filter: brightness(0) invert(1);
  pointer-events: none;
}

.rk-modal__head,
.rk-modal__body,
.rk-modal__foot {
  padding: 14px 16px !important;
}

.rk-modal__head {
  min-height: 54px;
}

.rk-modal__title {
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: 9px;
  font-size: 16px !important;
}

.rk-modal__title::before {
  content: "";
  width: 8px;
  height: 8px;
  border-radius: 999px;
  background: var(--rk-yellow);
  box-shadow: 0 0 16px rgba(247,209,0,.58);
}

/* 토스트: 글자만 큰 형태 제거 */
.rk-toast {
  display: block !important;
  pointer-events: none;
  opacity: 0;
  right: 22px !important;
  bottom: 22px !important;
  width: min(360px, calc(100vw - 44px));
  max-width: none !important;
  min-height: 52px;
  padding: 11px 14px 11px 46px !important;
  border-radius: 18px !important;
  font-size: 12px !important;
  font-weight: 700 !important;
  color: var(--rk-text-soft) !important;
  transform: translateY(12px) scale(.985);
  transition:
    opacity var(--rk-normal) var(--rk-ease-glass),
    transform var(--rk-normal) var(--rk-ease-glass);
}

.rk-toast.is-visible {
  pointer-events: auto;
  opacity: 1;
  transform: translateY(0) scale(1);
  animation: none !important;
}

.rk-toast::before {
  left: 16px !important;
  width: 10px !important;
  height: 10px !important;
  background: radial-gradient(circle, #fff6b0 0%, var(--rk-yellow) 60%, rgba(247,209,0,.36) 100%) !important;
}

.rk-toast::after {
  content: "";
  position: absolute;
  left: 14px;
  top: 50%;
  width: 14px;
  height: 14px;
  border-radius: 999px;
  border: 1px solid rgba(247,209,0,.24);
  transform: translateY(-50%);
}

.rk-toast__title {
  display: block;
  color: var(--rk-text);
  font-size: 12px;
  line-height: 1.25;
}

.rk-toast__desc {
  display: block;
  margin-top: 2px;
  color: var(--rk-text-muted);
  font-size: 11px;
  line-height: 1.35;
}

/* 인쇄/모바일 */
@keyframes rkModalInV3 {
  to {
    transform: translateY(0) scale(1);
  }
}

@media (max-width: 1180px) {
  .rk-search-line {
    grid-template-columns: minmax(260px, 1fr) 140px 140px auto auto !important;
  }
}

@media (max-width: 920px) {
  .rk-search-line {
    grid-template-columns: 1fr 1fr !important;
  }

  .rk-search-line .rk-input-wrap {
    grid-column: 1 / -1;
  }

  .rk-filter-drawer,
  .rk-filter-drawer.is-open {
    grid-template-columns: 1fr 1fr !important;
    max-height: 260px !important;
  }

  .rk-tabulator {
    height: 500px !important;
  }
}

@media (max-width: 620px) {
  .rk-search-line {
    grid-template-columns: 1fr !important;
  }

  .rk-filter-drawer,
  .rk-filter-drawer.is-open {
    grid-template-columns: 1fr !important;
    max-height: 420px !important;
  }

  .rk-tabulator {
    height: 460px !important;
  }
}



/*
  BY JS 2026-06-05 V4 보완
  사용법:
  - 본 블록은 V3 디자인 시스템 위에 얹는 보정 레이어다.
  - 타임라인, 상단 토스트, 상세창, 로고 로딩, 입력화면 높이 정렬, Tabulator 컴포넌트 공통화를 담당한다.
  - CI4 적용 시 design-system.css 하단에 유지한다.
*/

/* ========================================================================
   1. 전역 밀도 보정
   사용법: 카드 간격이 큰 화면에서는 body에 .rk-compact-page를 부여한다.
   ======================================================================== */
:root {
  --rk-card-gap-v4: 14px;
  --rk-card-pad-v4: 16px;
  --rk-card-pad-sm-v4: 13px;
  --rk-form-row-v4: 42px;
}

.rk-compact-page .rk-stack {
  gap: var(--rk-card-gap-v4) !important;
}

.rk-compact-page .rk-section + .rk-section {
  margin-top: var(--rk-card-gap-v4) !important;
}

.rk-compact-page .rk-card__body {
  padding: var(--rk-card-pad-v4) !important;
}

.rk-compact-page .rk-card__head {
  margin-bottom: 12px !important;
}

.rk-compact-page .rk-card__title {
  font-size: 15px !important;
}

.rk-compact-page .rk-card__desc {
  margin-top: 3px !important;
  font-size: 12px !important;
}

.rk-compact-page .rk-input,
.rk-compact-page .rk-select {
  height: var(--rk-form-row-v4) !important;
}

.rk-compact-page .rk-textarea {
  min-height: 92px !important;
}

/* ========================================================================
   2. 타임라인 V4
   사용법:
   <div class="rk-timeline rk-timeline--v4">
     <div class="rk-timeline-item is-current">
       <div class="rk-timeline-date">2026-06-05<span>17:20</span></div>
       <div class="rk-timeline-body">...</div>
     </div>
   </div>
   - 최신 항목을 위에 배치한다.
   - 기존 점/세로선 겹침을 방지하기 위해 grid 구조로 재정렬한다.
   ======================================================================== */
.rk-timeline--v4 {
  gap: 9px !important;
  padding: 0 !important;
}

.rk-timeline--v4 .rk-timeline-item {
  display: grid !important;
  grid-template-columns: 92px minmax(0, 1fr);
  gap: 12px;
  min-height: 62px;
  padding: 12px 13px !important;
  border: 1px solid rgba(255,255,255,.095) !important;
  border-radius: 16px !important;
  background:
    linear-gradient(180deg, rgba(255,255,255,.052), rgba(255,255,255,.025)),
    rgba(255,255,255,.024) !important;
}

.rk-timeline--v4 .rk-timeline-item::before,
.rk-timeline--v4 .rk-timeline-item::after {
  display: none !important;
}

.rk-timeline-date {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 5px;
  color: var(--rk-text-muted);
  font-size: 11px;
  line-height: 1.1;
  font-weight: 800;
  letter-spacing: .01em;
}

.rk-timeline-date::before {
  content: "";
  width: 8px;
  height: 8px;
  border-radius: 999px;
  background: currentColor;
  box-shadow: 0 0 14px currentColor;
  opacity: .72;
}

.rk-timeline-body {
  min-width: 0;
}

.rk-timeline-title {
  display: flex;
  align-items: center;
  gap: 8px;
  margin: 0;
  color: var(--rk-text);
  font-size: 13px;
  font-weight: 800;
}

.rk-timeline-desc {
  margin: 5px 0 0;
  color: var(--rk-text-muted);
  font-size: 12px;
  line-height: 1.45;
}

.rk-timeline--v4 .rk-timeline-item.is-current {
  border-color: rgba(247,209,0,.34) !important;
  background:
    linear-gradient(180deg, rgba(247,209,0,.15), rgba(247,209,0,.052)),
    rgba(255,255,255,.03) !important;
  box-shadow:
    0 16px 36px rgba(247,209,0,.075),
    inset 0 1px 0 rgba(255,255,255,.13) !important;
}

.rk-timeline--v4 .rk-timeline-item.is-current .rk-timeline-date,
.rk-timeline--v4 .rk-timeline-item.is-current .rk-timeline-title {
  color: var(--rk-yellow);
}

/* ========================================================================
   3. 상단 토스트 V4
   사용법:
   - 기본 토스트: .rk-toast
   - 상단 표시: .rk-toast.rk-toast--top
   - JS에서는 data-rk-toast-position="top" 속성으로 상단 표시 가능
   ======================================================================== */
.rk-toast--top {
  top: 22px !important;
  right: 22px !important;
  bottom: auto !important;
  transform: translateY(-12px) scale(.985) !important;
}

.rk-toast--top.is-visible {
  transform: translateY(0) scale(1) !important;
}

.rk-toast--top-left {
  top: 22px !important;
  left: 22px !important;
  right: auto !important;
  bottom: auto !important;
}

.rk-toast--brand {
  border-color: rgba(247,209,0,.28) !important;
}

.rk-toast--brand::before {
  box-shadow:
    0 0 16px rgba(247,209,0,.64),
    0 0 34px rgba(247,209,0,.22);
}

/* ========================================================================
   4. 모달/상세창 V4
   사용법:
   - 중앙 모달: .rk-modal.rk-modal--v4
   - 우측 상세창: .rk-detail-panel
   - 목록 상세, 읽기 화면, 미니 상세 레이어에 사용한다.
   ======================================================================== */
.rk-modal--v4 {
  width: min(100%, 460px) !important;
}

.rk-modal-hero {
  position: relative;
  overflow: hidden;
  min-height: 96px;
  padding: 18px;
  border-bottom: 1px solid var(--rk-line);
  background:
    radial-gradient(circle at 86% 16%, rgba(247,209,0,.16), transparent 38%),
    linear-gradient(135deg, rgba(255,255,255,.075), rgba(255,255,255,.025));
}

.rk-modal-hero::before {
  content: "";
  position: absolute;
  right: -26%;
  top: 52%;
  width: 120%;
  height: 2px;
  background: linear-gradient(90deg, transparent, rgba(247,209,0,.68), rgba(255,255,255,.22), transparent);
  filter: drop-shadow(0 0 18px rgba(247,209,0,.36));
  transform: translateY(-50%) skewX(-12deg);
  opacity: .42;
}

.rk-modal-hero__title {
  position: relative;
  margin: 0;
  font-size: 19px;
  font-weight: 900;
  letter-spacing: -.035em;
}

.rk-modal-hero__desc {
  position: relative;
  margin: 7px 0 0;
  color: var(--rk-text-muted);
  font-size: 12px;
}

.rk-detail-backdrop {
  position: fixed;
  inset: 0;
  z-index: 58;
  display: none;
  background: rgba(3,5,8,.48);
  backdrop-filter: blur(18px) saturate(1.2);
}

.rk-detail-backdrop.is-visible {
  display: block;
}

.rk-detail-panel {
  position: fixed;
  right: 18px;
  top: 18px;
  bottom: 18px;
  z-index: 59;
  display: flex;
  flex-direction: column;
  width: min(520px, calc(100vw - 36px));
  border: 1px solid rgba(255,255,255,.13);
  border-radius: 26px;
  background:
    linear-gradient(180deg, rgba(255,255,255,.086), rgba(255,255,255,.035)),
    rgba(13, 18, 25, .88);
  box-shadow:
    0 32px 90px rgba(0,0,0,.46),
    inset 0 1px 0 rgba(255,255,255,.09);
  backdrop-filter: blur(28px) saturate(1.3);
  transform: translateX(18px) scale(.985);
  opacity: 0;
  pointer-events: none;
  transition:
    opacity 300ms var(--rk-ease-glass),
    transform 300ms var(--rk-ease-glass);
}

.rk-detail-panel.is-visible {
  opacity: 1;
  pointer-events: auto;
  transform: translateX(0) scale(1);
}

.rk-detail-panel__head,
.rk-detail-panel__body,
.rk-detail-panel__foot {
  position: relative;
  z-index: 1;
  padding: 16px;
}

.rk-detail-panel__head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 14px;
  border-bottom: 1px solid var(--rk-line);
}

.rk-detail-panel__title {
  margin: 0;
  font-size: 18px;
  font-weight: 900;
  letter-spacing: -.035em;
}

.rk-detail-panel__sub {
  margin: 6px 0 0;
  color: var(--rk-text-muted);
  font-size: 12px;
}

.rk-detail-panel__body {
  flex: 1 1 auto;
  overflow: auto;
}

.rk-detail-panel__foot {
  display: flex;
  justify-content: flex-end;
  gap: 8px;
  border-top: 1px solid var(--rk-line);
}

.rk-detail-kv {
  display: grid;
  grid-template-columns: 118px minmax(0, 1fr);
  gap: 8px;
  padding: 10px 0;
  border-bottom: 1px solid rgba(255,255,255,.07);
}

.rk-detail-kv dt {
  color: var(--rk-text-muted);
  font-size: 12px;
  font-weight: 800;
}

.rk-detail-kv dd {
  margin: 0;
  color: var(--rk-text);
  font-size: 13px;
}

/* ========================================================================
   5. 로고 로딩 V4
   사용법:
   <div class="rk-logo-loader">
     <img src="assets/img/logo.svg" alt="">
   </div>
   - 로고가 만들어지는 느낌의 광선/마스크 로딩이다.
   ======================================================================== */
.rk-loader-card {
  min-height: 260px;
  padding: 28px;
  border: 1px solid var(--rk-line);
  border-radius: 26px;
  background:
    linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,.032)),
    rgba(13,18,25,.74);
  box-shadow: var(--rk-shadow-md);
  backdrop-filter: blur(26px) saturate(1.28);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
}

.rk-logo-loader {
  position: relative;
  width: 126px;
  height: 126px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.rk-logo-loader::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: 999px;
  background: radial-gradient(circle, rgba(247,209,0,.18), transparent 66%);
  animation: rkLoaderGlow 2.2s ease-in-out infinite;
}

.rk-logo-loader::after {
  content: "";
  position: absolute;
  left: -18%;
  top: 50%;
  width: 136%;
  height: 2px;
  background: linear-gradient(90deg, transparent, rgba(247,209,0,.9), rgba(255,255,255,.42), transparent);
  filter:
    drop-shadow(0 0 14px rgba(247,209,0,.6))
    drop-shadow(0 0 32px rgba(247,209,0,.24));
  transform: translateY(-50%) skewX(-14deg);
  animation: rkLogoBuildLine 1.75s var(--rk-ease-glass) infinite;
}

.rk-logo-loader img {
  position: relative;
  z-index: 1;
  width: 88px;
  filter:
    brightness(0) invert(1)
    drop-shadow(0 0 16px rgba(247,209,0,.34));
  clip-path: inset(0 100% 0 0);
  animation: rkLogoReveal 1.75s var(--rk-ease-glass) infinite;
}

.rk-loader-title {
  margin: 18px 0 0;
  font-size: 15px;
  font-weight: 900;
}

.rk-loader-desc {
  margin: 7px 0 0;
  color: var(--rk-text-muted);
  font-size: 12px;
}

/* ========================================================================
   6. 입력화면 높이 정렬 V4
   사용법:
   - .rk-form-equal-grid: 좌우 카드 높이를 행 단위로 동일하게 맞춘다.
   - .rk-eq-row-1: 기본정보 + 저장상태
   - .rk-eq-row-2: 상세내용 + 처리단계
   ======================================================================== */
.rk-form-equal-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 360px;
  gap: 14px;
  align-items: stretch;
}

.rk-form-equal-grid > .rk-card {
  height: 100%;
}

.rk-eq-row-1 {
  min-height: 238px;
}

.rk-eq-row-2 {
  min-height: 310px;
}

.rk-form-equal-grid .rk-card__body {
  height: 100%;
  display: flex;
  flex-direction: column;
}

.rk-fill {
  flex: 1 1 auto;
}

.rk-unit-field--compact .rk-input {
  height: 42px !important;
}

/* 수량/금액/중량 단위 입력 필드 내부 표기 */
.rk-unit-field {
  position: relative;
}

.rk-unit-field .rk-input {
  padding-right: 58px !important;
}

.rk-unit {
  position: absolute;
  right: 13px;
  top: 50%;
  transform: translateY(-50%);
  color: var(--rk-text-muted);
  font-size: 12px;
  font-weight: 900;
  pointer-events: none;
}

/* ========================================================================
   7. 컴포넌트 Tabulator 공통
   사용법:
   - #rk-component-grid: 컴포넌트 쇼케이스 테이블
   - #rk-work-grid: 목록 화면 테이블
   ======================================================================== */
.rk-component-grid {
  height: 360px !important;
  min-height: 360px !important;
}

/* ========================================================================
   8. 목록 화면 하단 여백/흰 영역 방지
   사용법:
   - body.rk-list-page-body를 목록 화면 body에 부여한다.
   - Tabulator footer, tableholder, placeholder까지 전부 다크 배경을 강제한다.
   ======================================================================== */
.rk-list-page-body {
  min-height: 100vh;
  background:
    radial-gradient(circle at 68% 18%, rgba(247, 209, 0, 0.095), transparent 24%),
    radial-gradient(circle at 24% 74%, rgba(255, 255, 255, 0.045), transparent 28%),
    linear-gradient(135deg, #040609 0%, #101620 52%, #05070a 100%) !important;
}

.rk-list-page-body .rk-content {
  padding-bottom: 14px !important;
}

.rk-list-page-body .rk-section + .rk-section {
  margin-top: 10px !important;
}

.rk-list-page-body .rk-tabulator {
  height: calc(100vh - 278px) !important;
  min-height: 560px !important;
  max-height: none !important;
}

.rk-list-page-body .tabulator,
.rk-list-page-body .tabulator-tableholder,
.rk-list-page-body .tabulator-table,
.rk-list-page-body .tabulator-footer,
.rk-list-page-body .tabulator-placeholder,
.rk-list-page-body .tabulator-calcs,
.rk-list-page-body .tabulator-calcs-holder,
.rk-list-page-body .tabulator-calcs-bottom {
  background-color: transparent !important;
}

.rk-list-page-body .tabulator-tableholder {
  background:
    linear-gradient(180deg, rgba(255,255,255,.018), rgba(255,255,255,.006)),
    rgba(5,7,10,.42) !important;
}

.rk-list-page-body .tabulator-footer {
  background:
    linear-gradient(180deg, rgba(255,255,255,.045), rgba(255,255,255,.018)),
    #0e141d !important;
}

/* ========================================================================
   9. 모바일 보정
   ======================================================================== */
@media (max-width: 1180px) {
  .rk-form-equal-grid {
    grid-template-columns: 1fr;
  }

  .rk-eq-row-1,
  .rk-eq-row-2 {
    min-height: auto;
  }

  .rk-list-page-body .rk-tabulator {
    height: 540px !important;
  }
}

@media (max-width: 760px) {
  .rk-detail-panel {
    inset: 10px;
    width: auto;
    border-radius: 22px;
  }

  .rk-detail-kv {
    grid-template-columns: 1fr;
  }

  .rk-timeline--v4 .rk-timeline-item {
    grid-template-columns: 1fr;
  }

  .rk-list-page-body .rk-tabulator {
    height: 480px !important;
  }
}

@keyframes rkLoaderGlow {
  0%, 100% {
    opacity: .5;
    transform: scale(.94);
  }
  50% {
    opacity: 1;
    transform: scale(1.08);
  }
}

@keyframes rkLogoBuildLine {
  0% {
    transform: translate(-62%, -50%) skewX(-14deg);
    opacity: 0;
  }
  16% {
    opacity: .9;
  }
  100% {
    transform: translate(62%, -50%) skewX(-14deg);
    opacity: 0;
  }
}

@keyframes rkLogoReveal {
  0% {
    clip-path: inset(0 100% 0 0);
    opacity: .54;
  }
  48% {
    clip-path: inset(0 0 0 0);
    opacity: 1;
  }
  100% {
    clip-path: inset(0 0 0 0);
    opacity: .82;
  }
}



/*
  BY JS 2026-06-05 V5 보완
  사용법:
  - V4 디자인 시스템 하단에 유지하는 보정 레이어다.
  - Tabulator 하단 흰색 영역, 행 hover, 상세 버튼, 토스트 로고, 심플 모달, 로고 로딩, 입력폼 레이아웃을 보정한다.
*/

/* ==========================================================================
   1. Tabulator 하단 흰색 영역 제거
   사용법:
   - Tabulator 컨테이너에는 .rk-tabulator 클래스를 반드시 같이 부여한다.
   - bottomCalc 사용 시 .tabulator-calcs 관련 셀까지 다크 배경을 강제한다.
   ========================================================================== */
.rk-tabulator,
.rk-tabulator.tabulator,
.rk-tabulator .tabulator-tableholder,
.rk-tabulator .tabulator-table,
.rk-tabulator .tabulator-footer,
.rk-tabulator .tabulator-footer-contents,
.rk-tabulator .tabulator-paginator,
.rk-tabulator .tabulator-placeholder,
.rk-tabulator .tabulator-calcs,
.rk-tabulator .tabulator-calcs-holder,
.rk-tabulator .tabulator-calcs-bottom {
  background: rgba(5, 7, 10, 0.42) !important;
  background-color: rgba(5, 7, 10, 0.42) !important;
  color: var(--rk-text) !important;
}

.rk-tabulator .tabulator-calcs .tabulator-row,
.rk-tabulator .tabulator-calcs-bottom .tabulator-row,
.rk-tabulator .tabulator-row.tabulator-calcs,
.rk-tabulator .tabulator-calcs .tabulator-cell,
.rk-tabulator .tabulator-calcs-bottom .tabulator-cell,
.rk-tabulator .tabulator-row.tabulator-calcs .tabulator-cell {
  background:
    linear-gradient(180deg, rgba(247, 209, 0, 0.095), rgba(247, 209, 0, 0.035)),
    #0e141d !important;
  color: rgba(247, 248, 250, 0.94) !important;
  border-top: 1px solid rgba(247, 209, 0, 0.18) !important;
  border-bottom: 0 !important;
  font-weight: 900 !important;
}

.rk-tabulator .tabulator-footer {
  min-height: 34px !important;
  padding: 4px 8px !important;
  border-top: 1px solid rgba(255, 255, 255, 0.13) !important;
}

.rk-tabulator .tabulator-footer::before {
  content: "";
  position: absolute;
  left: 18px;
  right: 18px;
  top: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(247,209,0,.34), transparent);
  pointer-events: none;
}

/* ==========================================================================
   2. Tabulator 행 hover / 선택 / 상태 개선
   사용법:
   - 상태는 JS makeBadge()가 .rk-badge를 반환한다.
   - 상세 버튼은 JS action 컬럼에서 .rk-grid-detail-btn으로 생성한다.
   ========================================================================== */
.rk-tabulator .tabulator-row {
  position: relative;
}

.rk-tabulator .tabulator-row::before {
  content: "";
  position: absolute;
  left: 0;
  top: 4px;
  bottom: 4px;
  width: 2px;
  border-radius: 999px;
  background: transparent;
  transition: background-color 160ms ease, box-shadow 160ms ease;
}

.rk-tabulator .tabulator-row:hover {
  background:
    linear-gradient(90deg, rgba(247, 209, 0, 0.12), rgba(255, 255, 255, 0.035)),
    rgba(247, 209, 0, 0.052) !important;
}

.rk-tabulator .tabulator-row:hover::before {
  background: var(--rk-yellow);
  box-shadow: 0 0 18px rgba(247,209,0,.58);
}

.rk-tabulator .tabulator-row.tabulator-selected {
  background:
    linear-gradient(90deg, rgba(247, 209, 0, 0.18), rgba(247, 209, 0, 0.07)),
    rgba(247, 209, 0, 0.06) !important;
}

.rk-tabulator .tabulator-row.tabulator-selected::before {
  background: var(--rk-yellow);
  box-shadow: 0 0 20px rgba(247,209,0,.66);
}

.rk-tabulator .tabulator-cell {
  font-weight: 750;
}

.rk-tabulator .tabulator-cell[tabulator-field="title"] {
  font-weight: 900;
}

.rk-grid-detail-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  height: 26px;
  padding: 0 10px;
  border: 1px solid rgba(247, 209, 0, 0.26);
  border-radius: 999px;
  background:
    linear-gradient(180deg, rgba(247,209,0,.15), rgba(247,209,0,.055));
  color: var(--rk-yellow);
  font-size: 11px;
  font-weight: 900;
  line-height: 1;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.12);
  cursor: pointer;
  transition:
    transform 160ms var(--rk-ease-glass),
    background-color 160ms var(--rk-ease-glass),
    border-color 160ms var(--rk-ease-glass);
}

.rk-grid-detail-btn:hover {
  transform: translateY(-1px);
  border-color: rgba(247, 209, 0, 0.5);
  background:
    linear-gradient(180deg, rgba(247,209,0,.24), rgba(247,209,0,.09));
}

/* 상태 배지 세부 정리 */
.rk-tabulator .rk-badge {
  min-width: 52px;
  justify-content: center;
  padding-inline: 8px !important;
}

.rk-tabulator .rk-badge::before {
  box-shadow:
    0 0 8px currentColor,
    0 0 18px color-mix(in srgb, currentColor 35%, transparent);
}

/* ==========================================================================
   3. 토스트 V5: 르노 로고 포함
   사용법:
   - .rk-toast 내부에 JS가 .rk-toast__logo, .rk-toast__title, .rk-toast__desc를 주입한다.
   ========================================================================== */
.rk-toast {
  min-height: 58px !important;
  padding: 11px 15px 11px 58px !important;
}

.rk-toast::before,
.rk-toast::after {
  display: none !important;
}

.rk-toast__logo {
  position: absolute;
  left: 15px;
  top: 50%;
  width: 28px;
  height: 28px;
  padding: 5px;
  border: 1px solid rgba(247, 209, 0, 0.22);
  border-radius: 11px;
  background:
    radial-gradient(circle, rgba(247,209,0,.18), transparent 68%),
    rgba(255,255,255,.04);
  transform: translateY(-50%);
  box-shadow:
    0 0 18px rgba(247,209,0,.18),
    inset 0 1px 0 rgba(255,255,255,.12);
}

.rk-toast__logo img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: contain;
  filter:
    brightness(0) invert(1)
    drop-shadow(0 0 10px rgba(247,209,0,.34));
}

.rk-toast__title {
  color: var(--rk-text);
  font-size: 12.5px;
  font-weight: 900;
}

.rk-toast__desc {
  color: var(--rk-text-muted);
  font-size: 11px;
}

/* ==========================================================================
   4. 모달 V5: 심플화
   사용법:
   - 기존 rk-modal--v4와 함께 적용된다.
   - 장식 히어로가 과하면 .rk-modal-hero는 최소 높이로 정리한다.
   ========================================================================== */
.rk-modal--v4 {
  width: min(100%, 420px) !important;
  border-radius: 22px !important;
}

.rk-modal--v4::before {
  left: 20px !important;
  right: 20px !important;
  opacity: .7;
}

.rk-modal--v4::after {
  opacity: .035 !important;
  width: 58px !important;
  height: 58px !important;
}

.rk-modal-hero {
  min-height: auto !important;
  padding: 16px 16px 12px !important;
  background:
    linear-gradient(180deg, rgba(255,255,255,.064), rgba(255,255,255,.024)) !important;
}

.rk-modal-hero::before {
  display: none !important;
}

.rk-modal-hero__title {
  font-size: 17px !important;
}

.rk-modal-hero__desc {
  margin-top: 5px !important;
}

.rk-modal__body {
  padding-top: 14px !important;
}

/* ==========================================================================
   5. 로고 로딩 V5: 속도 변화 + 위아래 빌드 라이트 + 그림자 끊김 방지
   사용법:
   - 기존 .rk-logo-loader 구조를 그대로 사용한다.
   - 부모 .rk-loader-card는 overflow: visible 상태여야 그림자가 끊기지 않는다.
   ========================================================================== */
.rk-loader-card {
  position: relative;
  overflow: visible !important;
  isolation: isolate;
}

.rk-loader-card::before {
  content: "";
  position: absolute;
  inset: -38px;
  z-index: -1;
  border-radius: 36px;
  background:
    radial-gradient(circle at 50% 45%, rgba(247,209,0,.18), transparent 44%),
    radial-gradient(circle at 50% 72%, rgba(247,209,0,.09), transparent 36%);
  filter: blur(18px);
  pointer-events: none;
}

.rk-logo-loader {
  overflow: visible !important;
}

.rk-logo-loader::before {
  inset: -20px !important;
  background:
    radial-gradient(circle, rgba(247,209,0,.18), transparent 54%),
    conic-gradient(from 90deg, transparent, rgba(247,209,0,.16), transparent 28%, transparent 100%);
  filter: blur(2px);
  animation: rkLoaderGlowV5 2.8s var(--rk-ease-glass) infinite !important;
}

.rk-logo-loader::after {
  left: -42% !important;
  top: 50% !important;
  width: 184% !important;
  height: 2px !important;
  animation: rkLogoBuildLineV5 2.35s var(--rk-ease-glass) infinite !important;
}

.rk-logo-loader .rk-logo-scan {
  position: absolute;
  left: 50%;
  top: -24%;
  z-index: 3;
  width: 2px;
  height: 148%;
  border-radius: 999px;
  background:
    linear-gradient(
      180deg,
      transparent,
      rgba(247,209,0,.22),
      rgba(255,255,255,.7),
      rgba(247,209,0,.26),
      transparent
    );
  filter:
    drop-shadow(0 0 10px rgba(247,209,0,.52))
    drop-shadow(0 0 28px rgba(247,209,0,.22));
  transform: translateX(-50%);
  animation: rkLogoVerticalBuildV5 2.35s var(--rk-ease-glass) infinite;
}

.rk-logo-loader .rk-logo-scan.rk-logo-scan--bottom {
  top: auto;
  bottom: -24%;
  animation-delay: .28s;
  opacity: .72;
}

.rk-logo-loader img {
  clip-path: inset(0 100% 0 0);
  animation: rkLogoRevealV5 2.35s var(--rk-ease-glass) infinite !important;
}

@keyframes rkLoaderGlowV5 {
  0%, 100% {
    opacity: .46;
    transform: scale(.92) rotate(0deg);
  }
  36% {
    opacity: 1;
    transform: scale(1.08) rotate(18deg);
  }
  68% {
    opacity: .76;
    transform: scale(1.02) rotate(32deg);
  }
}

@keyframes rkLogoBuildLineV5 {
  0% {
    transform: translate(-72%, -50%) skewX(-14deg) scaleX(.72);
    opacity: 0;
  }
  15% {
    opacity: .85;
  }
  48% {
    transform: translate(-10%, -50%) skewX(-14deg) scaleX(1.06);
    opacity: 1;
  }
  100% {
    transform: translate(72%, -50%) skewX(-14deg) scaleX(.88);
    opacity: 0;
  }
}

@keyframes rkLogoVerticalBuildV5 {
  0% {
    transform: translate(-72px, -16px) scaleY(.62);
    opacity: 0;
  }
  22% {
    opacity: .75;
  }
  52% {
    transform: translate(0, 0) scaleY(1.04);
    opacity: 1;
  }
  100% {
    transform: translate(72px, 16px) scaleY(.72);
    opacity: 0;
  }
}

@keyframes rkLogoRevealV5 {
  0% {
    clip-path: inset(0 100% 0 0);
    opacity: .5;
    transform: translateY(3px) scale(.985);
  }
  42% {
    clip-path: inset(0 12% 0 0);
    opacity: .92;
    transform: translateY(-2px) scale(1.01);
  }
  62% {
    clip-path: inset(0 0 0 0);
    opacity: 1;
    transform: translateY(0) scale(1);
  }
  100% {
    clip-path: inset(0 0 0 0);
    opacity: .82;
    transform: translateY(2px) scale(.995);
  }
}

/* ==========================================================================
   6. 입력 폼 V5: 처리단계 + 첨부파일 한 블럭 구성
   사용법:
   - .rk-process-attach-card 내부에 .rk-process-zone, .rk-attach-zone을 배치한다.
   ========================================================================== */
.rk-process-attach-card .rk-card__body {
  gap: 12px;
}

.rk-process-zone {
  padding-bottom: 12px;
  border-bottom: 1px solid var(--rk-line);
}

.rk-attach-zone {
  min-height: 118px;
}

.rk-process-attach-card .rk-dropzone {
  min-height: 118px !important;
  padding: 14px !important;
}

.rk-process-attach-card .rk-empty__icon {
  width: 42px;
  height: 42px;
  margin-bottom: 8px;
}

.rk-process-attach-card .rk-dropzone__title {
  margin: 6px 0 0 !important;
}

/* ==========================================================================
   7. 단위 누락 방지용 유틸
   사용법:
   - 단위가 필요한 모든 입력은 .rk-unit-field 안에 input + .rk-unit을 배치한다.
   ========================================================================== */
.rk-unit-field .rk-input.rk-number {
  font-variant-numeric: tabular-nums;
  text-align: right;
}

.rk-table .rk-number,
.rk-tabulator .tabulator-cell[tabulator-field="amount"],
.rk-tabulator .tabulator-cell[tabulator-field="qty"],
.rk-tabulator .tabulator-cell[tabulator-field="weight"] {
  font-variant-numeric: tabular-nums;
}



/*
  BY JS 2026-06-05 V6 보완
  사용법:
  - V5 하단에 유지하는 최종 보정 레이어다.
  - 로고 로딩의 사각형 클리핑 문제를 제거한다.
  - Tabulator 하단 계산행을 제거하고 페이지네이션을 다크톤으로 정리한다.
  - 입력화면 상세내용 카드에서 내용 입력칸과 수량/단가 영역이 겹치지 않도록 폼 그리드를 재정의한다.
*/

/* ==========================================================================
   1. 로고 로딩 V6: 클립 제거 + 광선 빌드 방식
   사용법:
   - .rk-logo-loader 안에 .rk-logo-scan, .rk-logo-scan--bottom, img를 배치한다.
   - img에는 clip-path를 쓰지 않는다. 그림자가 사각 영역에서 끊기는 원인이기 때문이다.
   ========================================================================== */
.rk-loader-card {
  overflow: visible !important;
  min-height: 236px;
  background:
    radial-gradient(circle at 50% 45%, rgba(247,209,0,.095), transparent 42%),
    linear-gradient(180deg, rgba(255,255,255,.074), rgba(255,255,255,.028)),
    rgba(13,18,25,.68) !important;
}

.rk-loader-card::before {
  inset: -70px !important;
  border-radius: 44px !important;
  background:
    radial-gradient(circle at 50% 45%, rgba(247,209,0,.18), transparent 34%),
    radial-gradient(circle at 50% 62%, rgba(247,209,0,.09), transparent 42%) !important;
  filter: blur(28px) !important;
}

.rk-logo-loader {
  width: 156px !important;
  height: 156px !important;
  overflow: visible !important;
  isolation: isolate;
}

.rk-logo-loader::before {
  inset: -46px !important;
  border-radius: 999px;
  background:
    radial-gradient(circle, rgba(247,209,0,.22), transparent 48%),
    conic-gradient(from 30deg, transparent 0deg, rgba(247,209,0,.18) 44deg, transparent 96deg, transparent 360deg) !important;
  filter: blur(12px) !important;
  opacity: .88;
  animation: rkLoaderHaloV6 3.4s cubic-bezier(.16,1,.3,1) infinite !important;
}

.rk-logo-loader::after {
  left: -58% !important;
  top: 50% !important;
  width: 216% !important;
  height: 2px !important;
  background:
    linear-gradient(
      90deg,
      transparent 0%,
      rgba(247,209,0,.1) 18%,
      rgba(247,209,0,.86) 46%,
      rgba(255,255,255,.72) 52%,
      rgba(247,209,0,.3) 62%,
      transparent 100%
    ) !important;
  filter:
    drop-shadow(0 0 14px rgba(247,209,0,.72))
    drop-shadow(0 0 42px rgba(247,209,0,.26)) !important;
  animation: rkLogoBuildLineV6 2.65s cubic-bezier(.16,1,.3,1) infinite !important;
  opacity: 0;
}

.rk-logo-loader .rk-logo-scan {
  position: absolute;
  left: 50%;
  top: -44%;
  z-index: 4;
  width: 2px;
  height: 188%;
  border-radius: 999px;
  background:
    linear-gradient(
      180deg,
      transparent,
      rgba(247,209,0,.18),
      rgba(255,255,255,.72),
      rgba(247,209,0,.2),
      transparent
    );
  filter:
    drop-shadow(0 0 10px rgba(247,209,0,.66))
    drop-shadow(0 0 30px rgba(247,209,0,.26));
  transform: translateX(-50%);
  animation: rkLogoVerticalBuildV6 2.65s cubic-bezier(.16,1,.3,1) infinite;
}

.rk-logo-loader .rk-logo-scan.rk-logo-scan--bottom {
  top: auto;
  bottom: -44%;
  opacity: .62;
  animation-delay: .24s;
}

.rk-logo-loader img {
  position: relative;
  z-index: 3;
  width: 96px !important;
  max-width: none;
  clip-path: none !important;
  opacity: .96;
  transform: none;
  filter:
    brightness(0) invert(1)
    drop-shadow(0 0 8px rgba(255,255,255,.16))
    drop-shadow(0 0 22px rgba(247,209,0,.42))
    drop-shadow(0 0 64px rgba(247,209,0,.22)) !important;
  animation: rkLogoMaterializeV6 2.65s cubic-bezier(.16,1,.3,1) infinite !important;
}

.rk-loader-title {
  margin-top: 20px !important;
}

@keyframes rkLoaderHaloV6 {
  0%, 100% {
    opacity: .48;
    transform: scale(.88) rotate(0deg);
  }
  38% {
    opacity: 1;
    transform: scale(1.1) rotate(20deg);
  }
  70% {
    opacity: .72;
    transform: scale(1.02) rotate(38deg);
  }
}

@keyframes rkLogoBuildLineV6 {
  0% {
    transform: translate(-80%, -50%) skewX(-14deg) scaleX(.58);
    opacity: 0;
  }
  14% {
    opacity: .9;
  }
  45% {
    transform: translate(-12%, -50%) skewX(-14deg) scaleX(1.14);
    opacity: 1;
  }
  76% {
    opacity: .48;
  }
  100% {
    transform: translate(80%, -50%) skewX(-14deg) scaleX(.72);
    opacity: 0;
  }
}

@keyframes rkLogoVerticalBuildV6 {
  0% {
    transform: translate(-74px, -20px) scaleY(.5);
    opacity: 0;
  }
  20% {
    opacity: .8;
  }
  50% {
    transform: translate(0, 0) scaleY(1.08);
    opacity: 1;
  }
  100% {
    transform: translate(74px, 20px) scaleY(.62);
    opacity: 0;
  }
}

@keyframes rkLogoMaterializeV6 {
  0% {
    opacity: .48;
    transform: translateY(4px) scale(.982);
    filter:
      brightness(0) invert(1)
      drop-shadow(0 0 0 rgba(247,209,0,0));
  }
  32% {
    opacity: .74;
    transform: translateY(-2px) scale(1.008);
  }
  55% {
    opacity: 1;
    transform: translateY(0) scale(1);
    filter:
      brightness(0) invert(1)
      drop-shadow(0 0 8px rgba(255,255,255,.18))
      drop-shadow(0 0 30px rgba(247,209,0,.58))
      drop-shadow(0 0 86px rgba(247,209,0,.28));
  }
  100% {
    opacity: .86;
    transform: translateY(2px) scale(.996);
  }
}

/* ==========================================================================
   2. Tabulator 하단 정리 V6
   사용법:
   - 계산행(bottomCalc)은 JS에서 제거한다.
   - 페이지네이션 footer는 남기되 한글 라벨과 다크 배경만 사용한다.
   ========================================================================== */
.rk-tabulator {
  overflow: hidden !important;
}

.rk-tabulator .tabulator-calcs,
.rk-tabulator .tabulator-calcs-holder,
.rk-tabulator .tabulator-calcs-bottom,
.rk-tabulator .tabulator-row.tabulator-calcs {
  display: none !important;
}

.rk-tabulator .tabulator-footer {
  height: 42px !important;
  min-height: 42px !important;
  padding: 6px 10px !important;
  background:
    linear-gradient(180deg, rgba(255,255,255,.045), rgba(255,255,255,.018)),
    #0b1119 !important;
  border-top: 1px solid rgba(255,255,255,.12) !important;
}

.rk-tabulator .tabulator-footer .tabulator-page-size {
  display: none !important;
}

.rk-tabulator .tabulator-pages {
  display: inline-flex;
  gap: 4px;
  vertical-align: middle;
}

.rk-tabulator .tabulator-page {
  height: 28px !important;
  min-width: 30px !important;
  padding: 0 9px !important;
  border-radius: 10px !important;
  border: 1px solid rgba(255,255,255,.12) !important;
  background: rgba(255,255,255,.045) !important;
  color: var(--rk-text-soft) !important;
  font-size: 11px !important;
  font-weight: 900 !important;
}

.rk-tabulator .tabulator-page[data-page="first"],
.rk-tabulator .tabulator-page[data-page="prev"],
.rk-tabulator .tabulator-page[data-page="next"],
.rk-tabulator .tabulator-page[data-page="last"] {
  min-width: 46px !important;
}

.rk-tabulator .tabulator-page.active {
  border-color: transparent !important;
  background: var(--rk-yellow) !important;
  color: #111 !important;
}

.rk-tabulator .tabulator-page:disabled {
  opacity: .34 !important;
  cursor: not-allowed;
}

.rk-tabulator .tabulator-tableholder {
  background:
    linear-gradient(180deg, rgba(255,255,255,.014), rgba(255,255,255,.006)),
    rgba(5,7,10,.42) !important;
}

/* ==========================================================================
   3. 입력 화면 겹침 방지 V6
   사용법:
   - 상세내용 카드 내부는 .rk-detail-form-grid를 사용한다.
   - textarea에 height:100%를 직접 주지 않는다.
   ========================================================================== */
.rk-detail-form-grid {
  display: grid;
  grid-template-rows: auto minmax(96px, 1fr) auto;
  gap: 12px;
  height: 100%;
  min-height: 0;
}

.rk-detail-form-grid .rk-textarea {
  min-height: 108px !important;
  height: 108px !important;
  max-height: 130px;
}

.rk-detail-form-grid .rk-grid {
  align-self: end;
}

.rk-eq-row-2 {
  min-height: 336px !important;
}

.rk-process-attach-card .rk-card__body {
  display: grid !important;
  grid-template-rows: auto 1fr;
}

.rk-process-zone {
  min-height: 138px;
}

.rk-attach-zone {
  min-height: 150px;
}

.rk-process-attach-card .rk-dropzone {
  min-height: 102px !important;
}

/* ==========================================================================
   4. 모든 단위형 표시 보강
   사용법:
   - 수량/금액/중량/길이는 .rk-unit-field 안에 배치한다.
   - 테이블 formatter는 JS에서 원/건/kg 단위를 붙인다.
   ========================================================================== */
.rk-unit {
  min-width: 24px;
  text-align: right;
}

.rk-unit-field .rk-input {
  padding-right: 62px !important;
}

/* ==========================================================================
   5. 상단 토스트와 상세창 보정
   ========================================================================== */
.rk-toast--top {
  top: 18px !important;
}

.rk-detail-panel__body {
  scrollbar-color: rgba(247,209,0,.34) rgba(255,255,255,.055);
}

/* ==========================================================================
   6. 모바일 보정
   ========================================================================== */
@media (max-width: 760px) {
  .rk-detail-form-grid {
    grid-template-rows: auto auto auto;
  }

  .rk-detail-form-grid .rk-textarea {
    height: 120px !important;
    max-height: none;
  }

  .rk-eq-row-2 {
    min-height: auto !important;
  }
}



/*
  BY JS 2026-06-05 V7 보완
  사용법:
  - 모든 드롭다운은 .rk-select-menu 커스텀 드롭다운을 사용한다.
  - 드롭다운 z-index는 일반 카드보다 높고, 모달/상세창/토스트보다 낮게 유지한다.
  - 로고 로딩은 .rk-logo-edge를 사용하여 로고 실루엣을 따라 빛이 도는 느낌을 만든다.
  - Tabulator 라운딩/페이지네이션 색상 충돌을 단일 톤으로 정리한다.
*/

/* ==========================================================================
   1. 커스텀 드롭다운 V7
   사용법:
   <div class="rk-select-menu" data-rk-select-menu>
     <button type="button" class="rk-select-button"><span data-rk-select-label>전체</span><span class="rk-select-arrow"></span></button>
     <div class="rk-select-list"><button class="rk-select-option">전체</button></div>
     <input type="hidden" name="status" value="전체">
   </div>
   ========================================================================== */
.rk-select,
select.rk-select {
  display: none !important;
}

.rk-card:has(.rk-select-menu),
.rk-search-panel:has(.rk-select-menu),
.rk-modal:has(.rk-select-menu),
.rk-detail-panel:has(.rk-select-menu) {
  overflow: visible !important;
}

.rk-select-wrap {
  overflow: visible !important;
}

.rk-select-menu {
  position: relative;
  z-index: 36;
  width: 100%;
}

.rk-select-menu.is-open {
  z-index: 46;
}

.rk-select-button {
  position: relative;
  width: 100%;
  height: 44px;
  padding: 0 40px 0 13px;
  border: 1px solid var(--rk-line);
  border-radius: var(--rk-radius-md);
  outline: 0;
  background:
    linear-gradient(180deg, rgba(255,255,255,.07), rgba(255,255,255,.032)),
    rgba(255,255,255,.044);
  color: var(--rk-text);
  font-size: 13px;
  font-weight: 800;
  text-align: left;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.08),
    0 10px 24px rgba(0,0,0,.16);
  cursor: pointer;
  transition:
    border-color 220ms var(--rk-ease-glass),
    background 220ms var(--rk-ease-glass),
    box-shadow 220ms var(--rk-ease-glass),
    transform 220ms var(--rk-ease-glass);
}

.rk-select-button:hover,
.rk-select-menu.is-open .rk-select-button {
  border-color: rgba(247,209,0,.38);
  background:
    linear-gradient(180deg, rgba(255,255,255,.09), rgba(255,255,255,.044)),
    rgba(255,255,255,.056);
  box-shadow:
    0 0 0 4px rgba(247,209,0,.06),
    inset 0 1px 0 rgba(255,255,255,.12),
    0 14px 30px rgba(0,0,0,.22);
}

.rk-select-arrow {
  position: absolute;
  right: 14px;
  top: 50%;
  width: 9px;
  height: 9px;
  border-right: 2px solid currentColor;
  border-bottom: 2px solid currentColor;
  color: var(--rk-text-muted);
  transform: translateY(-64%) rotate(45deg);
  transition:
    transform 260ms var(--rk-ease-glass),
    color 220ms var(--rk-ease-glass);
}

.rk-select-menu.is-open .rk-select-arrow {
  color: var(--rk-yellow);
  transform: translateY(-30%) rotate(225deg);
}

.rk-select-list {
  position: absolute;
  left: 0;
  right: 0;
  top: calc(100% + 7px);
  z-index: 46;
  max-height: 240px;
  overflow: auto;
  padding: 6px;
  border: 1px solid rgba(255,255,255,.13);
  border-radius: 16px;
  background:
    linear-gradient(180deg, rgba(255,255,255,.09), rgba(255,255,255,.034)),
    rgba(12, 17, 24, .96);
  box-shadow:
    0 22px 54px rgba(0,0,0,.38),
    inset 0 1px 0 rgba(255,255,255,.12);
  backdrop-filter: blur(24px) saturate(1.32);
  pointer-events: none;
  opacity: 0;
  transform: translateY(-9px) scale(.975);
  transform-origin: top center;
  transition:
    opacity 260ms var(--rk-ease-glass),
    transform 260ms var(--rk-ease-glass);
}

.rk-select-menu.is-open .rk-select-list {
  pointer-events: auto;
  opacity: 1;
  transform: translateY(0) scale(1);
}

.rk-select-option {
  display: flex;
  align-items: center;
  width: 100%;
  min-height: 34px;
  padding: 0 10px;
  border: 0;
  border-radius: 11px;
  background: transparent;
  color: var(--rk-text-soft);
  font-size: 12.5px;
  font-weight: 800;
  text-align: left;
  cursor: pointer;
  transition:
    background-color 180ms var(--rk-ease-glass),
    color 180ms var(--rk-ease-glass),
    transform 180ms var(--rk-ease-glass);
}

.rk-select-option:hover {
  background: rgba(255,255,255,.07);
  color: var(--rk-text);
}

.rk-select-option.is-selected {
  background:
    linear-gradient(135deg, rgba(247,209,0,.95), rgba(255,230,135,.96));
  color: #101010;
  box-shadow:
    0 10px 22px rgba(247,209,0,.16),
    inset 0 1px 0 rgba(255,255,255,.42);
}

/* 드롭다운 레이어 정책 */
.rk-modal-backdrop { z-index: 60 !important; }
.rk-detail-backdrop { z-index: 58 !important; }
.rk-detail-panel { z-index: 59 !important; }
.rk-toast { z-index: 80 !important; }

/* ==========================================================================
   2. 로고 로딩 V7: 실루엣 테두리 글로우 + 색 변화
   사용법:
   - .rk-logo-edge는 img와 같은 logo.svg를 CSS mask로 사용한다.
   - 로고 원본은 움직임을 줄이고, edge/glow/scan이 움직인다.
   ========================================================================== */
.rk-logo-loader {
  width: 168px !important;
  height: 168px !important;
}

.rk-logo-loader::before {
  inset: -58px !important;
  background:
    radial-gradient(circle, rgba(247,209,0,.24), transparent 45%),
    conic-gradient(from var(--rk-logo-angle, 0deg), transparent 0deg, rgba(247,209,0,.18) 48deg, rgba(255,255,255,.08) 68deg, transparent 120deg, transparent 360deg) !important;
  filter: blur(14px) !important;
  animation: rkLoaderHaloV7 4.4s cubic-bezier(.16,1,.3,1) infinite !important;
}

.rk-logo-loader::after {
  height: 1.5px !important;
  animation: rkLogoBuildLineV7 3.2s cubic-bezier(.16,1,.3,1) infinite !important;
}

.rk-logo-edge {
  position: absolute;
  z-index: 5;
  width: 106px;
  height: 106px;
  background:
    conic-gradient(
      from var(--rk-logo-angle, 0deg),
      rgba(247,209,0,.12),
      rgba(255,255,255,.92),
      rgba(247,209,0,.78),
      rgba(255,224,102,.28),
      rgba(247,209,0,.12)
    );
  -webkit-mask: url("../img/logo.svg") center / contain no-repeat;
  mask: url("../img/logo.svg") center / contain no-repeat;
  filter:
    drop-shadow(0 0 10px rgba(255,255,255,.22))
    drop-shadow(0 0 28px rgba(247,209,0,.52))
    drop-shadow(0 0 74px rgba(247,209,0,.26));
  opacity: .78;
  animation: rkLogoEdgeGlowV7 3.2s cubic-bezier(.16,1,.3,1) infinite;
  pointer-events: none;
}

.rk-logo-loader img {
  width: 98px !important;
  opacity: .96;
  animation: rkLogoMaterializeV7 3.2s cubic-bezier(.16,1,.3,1) infinite !important;
}

.rk-logo-loader .rk-logo-scan {
  height: 192% !important;
  animation: rkLogoVerticalBuildV7 3.2s cubic-bezier(.16,1,.3,1) infinite !important;
}

.rk-logo-loader .rk-logo-scan.rk-logo-scan--bottom {
  animation-delay: .36s !important;
}

@keyframes rkLoaderHaloV7 {
  0%, 100% {
    --rk-logo-angle: 0deg;
    opacity: .48;
    transform: scale(.9) rotate(0deg);
  }
  34% {
    --rk-logo-angle: 130deg;
    opacity: 1;
    transform: scale(1.1) rotate(16deg);
  }
  68% {
    --rk-logo-angle: 260deg;
    opacity: .74;
    transform: scale(1.02) rotate(28deg);
  }
}

@keyframes rkLogoEdgeGlowV7 {
  0% {
    --rk-logo-angle: 0deg;
    opacity: .36;
    transform: scale(.985);
  }
  22% {
    opacity: .9;
  }
  48% {
    --rk-logo-angle: 180deg;
    opacity: 1;
    transform: scale(1.025);
  }
  100% {
    --rk-logo-angle: 360deg;
    opacity: .52;
    transform: scale(1);
  }
}

@keyframes rkLogoMaterializeV7 {
  0% {
    opacity: .72;
    transform: translateY(2px) scale(.992);
    filter:
      brightness(0) invert(1)
      drop-shadow(0 0 8px rgba(255,255,255,.12))
      drop-shadow(0 0 18px rgba(247,209,0,.28));
  }
  46% {
    opacity: 1;
    transform: translateY(-2px) scale(1.012);
    filter:
      brightness(0) invert(1)
      drop-shadow(0 0 12px rgba(255,255,255,.24))
      drop-shadow(0 0 38px rgba(247,209,0,.62))
      drop-shadow(0 0 92px rgba(247,209,0,.28));
  }
  100% {
    opacity: .86;
    transform: translateY(1px) scale(.998);
  }
}

@keyframes rkLogoBuildLineV7 {
  0% {
    transform: translate(-86%, -50%) skewX(-14deg) scaleX(.42);
    opacity: 0;
  }
  16% {
    opacity: .74;
  }
  44% {
    transform: translate(-8%, -50%) skewX(-14deg) scaleX(1.04);
    opacity: .88;
  }
  100% {
    transform: translate(86%, -50%) skewX(-14deg) scaleX(.52);
    opacity: 0;
  }
}

@keyframes rkLogoVerticalBuildV7 {
  0% {
    transform: translate(-82px, -18px) scaleY(.45);
    opacity: 0;
  }
  20% {
    opacity: .72;
  }
  52% {
    transform: translate(0, 0) scaleY(1);
    opacity: .86;
  }
  100% {
    transform: translate(82px, 18px) scaleY(.55);
    opacity: 0;
  }
}

/* ==========================================================================
   3. Tabulator 라운딩/페이지네이션 V7
   사용법:
   - 중첩 색상 충돌을 줄이기 위해 footer와 paginator의 배경 레이어를 단순화한다.
   ========================================================================== */
.rk-tabulator,
.rk-tabulator.tabulator {
  border: 1px solid rgba(255,255,255,.12) !important;
  border-radius: 20px !important;
  background: #0a0f16 !important;
  box-shadow:
    0 22px 54px rgba(0,0,0,.34),
    inset 0 1px 0 rgba(255,255,255,.08) !important;
}

.rk-tabulator .tabulator-header {
  border-radius: 19px 19px 0 0 !important;
  background: #101720 !important;
}

.rk-tabulator .tabulator-tableholder {
  background: #0a0f16 !important;
}

.rk-tabulator .tabulator-footer {
  border-radius: 0 0 19px 19px !important;
  background: #0c121a !important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.07);
}

.rk-tabulator .tabulator-footer::before {
  opacity: .45;
}

.rk-tabulator .tabulator-paginator {
  color: var(--rk-text-muted) !important;
}

.rk-tabulator .tabulator-page {
  margin: 0 2px !important;
  background: rgba(255,255,255,.045) !important;
  border-color: rgba(255,255,255,.1) !important;
  color: rgba(247,248,250,.68) !important;
  box-shadow: none !important;
}

.rk-tabulator .tabulator-page:not(.active):not(:disabled):hover {
  background: rgba(255,255,255,.07) !important;
  border-color: rgba(247,209,0,.26) !important;
  color: var(--rk-yellow) !important;
}

.rk-tabulator .tabulator-page.active {
  background: var(--rk-yellow) !important;
  border-color: var(--rk-yellow) !important;
  color: #111 !important;
  box-shadow: 0 8px 18px rgba(247,209,0,.18) !important;
}

.rk-tabulator .tabulator-page:disabled {
  background: rgba(255,255,255,.026) !important;
  border-color: rgba(255,255,255,.065) !important;
  color: rgba(247,248,250,.28) !important;
}

.rk-tabulator .tabulator-row:hover {
  background:
    linear-gradient(90deg, rgba(247,209,0,.095), rgba(255,255,255,.028)),
    #111720 !important;
}

/* ==========================================================================
   4. 입력 화면 커스텀 드롭다운 높이 보정
   ========================================================================== */
.rk-compact-page .rk-select-button {
  height: var(--rk-form-row-v4) !important;
}

.rk-field .rk-select-menu {
  min-width: 0;
}



/*
  BY JS 2026-06-05 V8 보완
  사용법:
  - 모든 일반 페이지 하단에 .rk-footer를 배치한다.
  - 로그인 화면은 .rk-footer--login을 함께 사용해 더 작게 표시한다.
  - 푸터는 콘텐츠를 방해하지 않는 낮은 높이의 르노 스타일 리퀴드 글라스 영역이다.
*/

/* ==========================================================================
   1. 르노 스타일 푸터
   ========================================================================== */
.rk-footer {
  position: relative;
  z-index: 5;
  overflow: hidden;
  margin: 8px 28px 24px calc(var(--rk-sidebar-width) + 28px);
  border: 1px solid rgba(255,255,255,.105);
  border-radius: 22px;
  background:
    linear-gradient(180deg, rgba(255,255,255,.074), rgba(255,255,255,.028)),
    rgba(8, 12, 18, .72);
  box-shadow:
    0 22px 54px rgba(0,0,0,.28),
    inset 0 1px 0 rgba(255,255,255,.08);
  backdrop-filter: blur(24px) saturate(1.24);
}

.rk-footer::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    radial-gradient(circle at 14% 50%, rgba(247,209,0,.095), transparent 24%),
    linear-gradient(115deg, transparent 0%, rgba(255,255,255,.04) 48%, transparent 49%);
  opacity: .86;
}

.rk-footer__light {
  position: absolute;
  right: -46%;
  top: 50%;
  width: 82%;
  height: 1px;
  background:
    linear-gradient(90deg, transparent, rgba(247,209,0,.62), rgba(255,255,255,.2), transparent);
  filter:
    drop-shadow(0 0 14px rgba(247,209,0,.38))
    drop-shadow(0 0 34px rgba(247,209,0,.18));
  transform: translateY(-50%) skewX(-14deg);
  animation: rkFooterLight 8.2s cubic-bezier(.16,1,.3,1) infinite;
  opacity: 0;
  pointer-events: none;
}

.rk-footer__inner {
  position: relative;
  z-index: 1;
  min-height: 68px;
  display: grid;
  grid-template-columns: minmax(230px, .9fr) auto minmax(220px, .75fr);
  align-items: center;
  gap: 18px;
  padding: 12px 18px;
}

.rk-footer-brand {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  min-width: 0;
}

.rk-footer-brand__mark {
  position: relative;
  width: 38px;
  height: 38px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid rgba(247,209,0,.18);
  border-radius: 14px;
  background:
    radial-gradient(circle, rgba(247,209,0,.14), transparent 66%),
    rgba(255,255,255,.04);
  box-shadow:
    0 0 22px rgba(247,209,0,.14),
    inset 0 1px 0 rgba(255,255,255,.1);
}

.rk-footer-brand__mark img {
  width: 24px;
  height: 24px;
  object-fit: contain;
  filter:
    brightness(0) invert(1)
    drop-shadow(0 0 10px rgba(247,209,0,.34));
}

.rk-footer-brand__text {
  min-width: 0;
}

.rk-footer-brand__text strong {
  display: block;
  color: var(--rk-text);
  font-size: 12px;
  line-height: 1;
  font-weight: 900;
  letter-spacing: .11em;
  white-space: nowrap;
}

.rk-footer-brand__text em {
  display: block;
  margin-top: 6px;
  color: var(--rk-text-muted);
  font-size: 11px;
  line-height: 1;
  font-style: normal;
  font-weight: 800;
}

.rk-footer-nav {
  display: inline-flex;
  justify-content: center;
  gap: 6px;
  padding: 4px;
  border: 1px solid rgba(255,255,255,.075);
  border-radius: 999px;
  background: rgba(255,255,255,.035);
}

.rk-footer-nav a {
  min-height: 30px;
  display: inline-flex;
  align-items: center;
  padding: 0 11px;
  border-radius: 999px;
  color: var(--rk-text-soft);
  font-size: 11px;
  font-weight: 900;
  transition:
    background-color 160ms var(--rk-ease-glass),
    color 160ms var(--rk-ease-glass);
}

.rk-footer-nav a:hover {
  background: rgba(247,209,0,.12);
  color: var(--rk-yellow);
}

.rk-footer-meta {
  justify-self: end;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  min-width: 0;
}

.rk-footer-state {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  min-height: 28px;
  padding: 0 10px;
  border: 1px solid rgba(247,209,0,.24);
  border-radius: 999px;
  background: rgba(247,209,0,.082);
  color: var(--rk-yellow);
  font-size: 10.5px;
  font-weight: 900;
  letter-spacing: .06em;
  white-space: nowrap;
}

.rk-footer-state::before {
  content: "";
  width: 5px;
  height: 5px;
  border-radius: 999px;
  background: var(--rk-yellow);
  box-shadow: 0 0 12px rgba(247,209,0,.72);
}

.rk-footer-copy {
  color: var(--rk-text-muted);
  font-size: 10.5px;
  font-weight: 800;
  letter-spacing: .02em;
  white-space: nowrap;
}

/* 로그인 전용 푸터 */
.rk-footer--login {
  width: min(980px, calc(100% - 56px));
  margin: -8px auto 24px;
}

.rk-footer--login .rk-footer__inner {
  grid-template-columns: minmax(230px, 1fr) minmax(220px, auto);
}

.rk-footer--login .rk-footer-nav {
  display: none;
}

/* 목록 화면은 테이블 가시성을 위해 푸터를 더 낮게 유지한다. */
.rk-list-page-body .rk-footer {
  margin-top: 6px;
  margin-bottom: 14px;
}

.rk-list-page-body .rk-footer__inner {
  min-height: 58px;
  padding-top: 9px;
  padding-bottom: 9px;
}

@keyframes rkFooterLight {
  0% {
    transform: translate(0, -50%) skewX(-14deg) scaleX(.7);
    opacity: 0;
  }
  14% {
    opacity: .68;
  }
  52% {
    opacity: .34;
  }
  100% {
    transform: translate(-148%, -50%) skewX(-14deg) scaleX(1);
    opacity: 0;
  }
}

/* ==========================================================================
   2. 반응형 푸터
   ========================================================================== */
@media (max-width: 1180px) {
  .rk-footer {
    margin-left: 16px;
    margin-right: 16px;
  }

  .rk-footer__inner {
    grid-template-columns: 1fr;
    justify-items: start;
    gap: 10px;
  }

  .rk-footer-nav {
    justify-content: flex-start;
  }

  .rk-footer-meta {
    justify-self: start;
  }
}

@media (max-width: 640px) {
  .rk-footer {
    border-radius: 18px;
    margin: 8px 12px 16px;
  }

  .rk-footer__inner {
    padding: 12px;
  }

  .rk-footer-nav {
    flex-wrap: wrap;
    border-radius: 16px;
  }

  .rk-footer-meta {
    flex-wrap: wrap;
  }

  .rk-footer-copy {
    white-space: normal;
  }
}



/*
  BY JS 2026-06-05 V9 보완
  사용법:
  - V8 하단에 유지하는 로고 로딩/Tabulator footer 최종 보정 레이어다.
  - 로고 로딩은 배경 빛 범위를 줄이고, 로고 자체의 글로우/테두리 변화폭을 키운다.
  - 애니메이션 반복 시작/종료 구간을 느리게 처리하여 끊김을 줄인다.
  - Tabulator footer / footer-contents / paginator는 헤더와 같은 톤으로 통일한다.
*/

/* ==========================================================================
   1. 로고 로딩 V9: 배경 빛 축소 + 로고 자체 변화폭 확대
   ========================================================================== */
.rk-loader-card {
  overflow: visible !important;
  background:
    radial-gradient(circle at 50% 47%, rgba(247,209,0,.07), transparent 30%),
    linear-gradient(180deg, rgba(255,255,255,.074), rgba(255,255,255,.028)),
    rgba(13,18,25,.72) !important;
}

.rk-loader-card::before {
  inset: -42px !important;
  border-radius: 38px !important;
  background:
    radial-gradient(circle at 50% 48%, rgba(247,209,0,.13), transparent 30%),
    radial-gradient(circle at 50% 63%, rgba(247,209,0,.045), transparent 34%) !important;
  filter: blur(18px) !important;
  opacity: .78;
}

.rk-logo-loader {
  width: 172px !important;
  height: 172px !important;
  overflow: visible !important;
  isolation: isolate;
}

.rk-logo-loader::before {
  inset: -28px !important;
  border-radius: 999px;
  background:
    radial-gradient(circle, rgba(247,209,0,.19), transparent 42%),
    conic-gradient(from 0deg, transparent 0deg, rgba(247,209,0,.13) 42deg, rgba(255,255,255,.06) 58deg, transparent 104deg, transparent 360deg) !important;
  filter: blur(8px) !important;
  animation: rkLoaderHaloV9 5.2s cubic-bezier(.45, 0, .2, 1) infinite !important;
}

.rk-logo-loader::after {
  left: -28% !important;
  top: 50% !important;
  width: 156% !important;
  height: 1.5px !important;
  background:
    linear-gradient(
      90deg,
      transparent 0%,
      rgba(247,209,0,.08) 20%,
      rgba(247,209,0,.62) 46%,
      rgba(255,255,255,.48) 52%,
      rgba(247,209,0,.18) 62%,
      transparent 100%
    ) !important;
  filter:
    drop-shadow(0 0 10px rgba(247,209,0,.48))
    drop-shadow(0 0 24px rgba(247,209,0,.16)) !important;
  opacity: 0;
  animation: rkLogoBuildLineV9 5.2s cubic-bezier(.45, 0, .2, 1) infinite !important;
}

.rk-logo-edge {
  width: 112px !important;
  height: 112px !important;
  background:
    conic-gradient(
      from 0deg,
      rgba(247,209,0,.1),
      rgba(255,255,255,.96),
      rgba(247,209,0,.88),
      rgba(255,224,102,.22),
      rgba(247,209,0,.1)
    ) !important;
  filter:
    drop-shadow(0 0 8px rgba(255,255,255,.16))
    drop-shadow(0 0 22px rgba(247,209,0,.44))
    drop-shadow(0 0 56px rgba(247,209,0,.18)) !important;
  animation: rkLogoEdgeGlowV9 5.2s cubic-bezier(.45, 0, .2, 1) infinite !important;
}

.rk-logo-loader img {
  width: 100px !important;
  filter:
    brightness(0) invert(1)
    drop-shadow(0 0 7px rgba(255,255,255,.12))
    drop-shadow(0 0 18px rgba(247,209,0,.34))
    drop-shadow(0 0 44px rgba(247,209,0,.12)) !important;
  animation: rkLogoMaterializeV9 5.2s cubic-bezier(.45, 0, .2, 1) infinite !important;
}

.rk-logo-loader .rk-logo-scan {
  top: -20% !important;
  height: 140% !important;
  opacity: .7;
  filter:
    drop-shadow(0 0 8px rgba(247,209,0,.46))
    drop-shadow(0 0 18px rgba(247,209,0,.16)) !important;
  animation: rkLogoVerticalBuildV9 5.2s cubic-bezier(.45, 0, .2, 1) infinite !important;
}

.rk-logo-loader .rk-logo-scan.rk-logo-scan--bottom {
  bottom: -20% !important;
  animation-delay: .18s !important;
}

@keyframes rkLoaderHaloV9 {
  0% {
    opacity: .34;
    transform: scale(.88) rotate(0deg);
  }
  12% {
    opacity: .52;
    transform: scale(.94) rotate(5deg);
  }
  42% {
    opacity: .92;
    transform: scale(1.06) rotate(18deg);
  }
  68% {
    opacity: .62;
    transform: scale(.99) rotate(28deg);
  }
  88% {
    opacity: .38;
    transform: scale(.92) rotate(34deg);
  }
  100% {
    opacity: .34;
    transform: scale(.88) rotate(36deg);
  }
}

@keyframes rkLogoBuildLineV9 {
  0% {
    transform: translate(-44%, -50%) skewX(-12deg) scaleX(.18);
    opacity: 0;
  }
  14% {
    transform: translate(-38%, -50%) skewX(-12deg) scaleX(.36);
    opacity: .32;
  }
  42% {
    transform: translate(-4%, -50%) skewX(-12deg) scaleX(.88);
    opacity: .74;
  }
  64% {
    transform: translate(18%, -50%) skewX(-12deg) scaleX(.68);
    opacity: .42;
  }
  86% {
    transform: translate(38%, -50%) skewX(-12deg) scaleX(.24);
    opacity: .08;
  }
  100% {
    transform: translate(44%, -50%) skewX(-12deg) scaleX(.18);
    opacity: 0;
  }
}

@keyframes rkLogoEdgeGlowV9 {
  0% {
    opacity: .34;
    transform: scale(.955);
    filter:
      drop-shadow(0 0 6px rgba(255,255,255,.1))
      drop-shadow(0 0 14px rgba(247,209,0,.26))
      drop-shadow(0 0 28px rgba(247,209,0,.08));
  }
  18% {
    opacity: .58;
    transform: scale(.985);
  }
  46% {
    opacity: 1;
    transform: scale(1.055);
    filter:
      drop-shadow(0 0 11px rgba(255,255,255,.24))
      drop-shadow(0 0 34px rgba(247,209,0,.72))
      drop-shadow(0 0 76px rgba(247,209,0,.28));
  }
  72% {
    opacity: .66;
    transform: scale(1.01);
  }
  100% {
    opacity: .34;
    transform: scale(.955);
  }
}

@keyframes rkLogoMaterializeV9 {
  0% {
    opacity: .66;
    transform: translateY(3px) scale(.965);
    filter:
      brightness(0) invert(1)
      drop-shadow(0 0 6px rgba(255,255,255,.08))
      drop-shadow(0 0 12px rgba(247,209,0,.2));
  }
  18% {
    opacity: .82;
    transform: translateY(1px) scale(.99);
  }
  48% {
    opacity: 1;
    transform: translateY(-3px) scale(1.045);
    filter:
      brightness(0) invert(1)
      drop-shadow(0 0 12px rgba(255,255,255,.24))
      drop-shadow(0 0 36px rgba(247,209,0,.68))
      drop-shadow(0 0 86px rgba(247,209,0,.26));
  }
  76% {
    opacity: .84;
    transform: translateY(1px) scale(.998);
  }
  100% {
    opacity: .66;
    transform: translateY(3px) scale(.965);
  }
}

@keyframes rkLogoVerticalBuildV9 {
  0% {
    transform: translate(-42px, -8px) scaleY(.28);
    opacity: 0;
  }
  16% {
    opacity: .34;
  }
  46% {
    transform: translate(0, 0) scaleY(.82);
    opacity: .78;
  }
  76% {
    transform: translate(28px, 8px) scaleY(.42);
    opacity: .22;
  }
  100% {
    transform: translate(42px, 8px) scaleY(.28);
    opacity: 0;
  }
}

/* ==========================================================================
   2. Tabulator footer/header 톤 통일 V9
   ========================================================================== */
.rk-tabulator,
.rk-tabulator.tabulator {
  background: #0d131c !important;
  border-color: rgba(255,255,255,.12) !important;
}

.rk-tabulator .tabulator-header,
.rk-tabulator.tabulator .tabulator-header,
.rk-tabulator .tabulator-footer,
.rk-tabulator .tabulator-footer-contents,
.rk-tabulator .tabulator-paginator {
  background: #101720 !important;
  background-color: #101720 !important;
  color: var(--rk-text-soft) !important;
}

.rk-tabulator .tabulator-header {
  box-shadow: inset 0 -1px 0 rgba(255,255,255,.11) !important;
}

.rk-tabulator .tabulator-footer {
  height: 42px !important;
  min-height: 42px !important;
  padding: 6px 10px !important;
  border-top: 1px solid rgba(255,255,255,.11) !important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.06) !important;
}

.rk-tabulator .tabulator-footer::before {
  display: none !important;
}

.rk-tabulator .tabulator-footer-contents {
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: flex-end;
}

.rk-tabulator .tabulator-paginator {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 0 !important;
}

.rk-tabulator .tabulator-pages {
  display: inline-flex;
  align-items: center;
  gap: 4px;
}

.rk-tabulator .tabulator-page {
  height: 28px !important;
  min-width: 30px !important;
  margin: 0 !important;
  padding: 0 9px !important;
  border: 1px solid rgba(255,255,255,.12) !important;
  border-radius: 9px !important;
  background: rgba(255,255,255,.045) !important;
  color: rgba(247,248,250,.68) !important;
  box-shadow: none !important;
}

.rk-tabulator .tabulator-page:not(.active):not(:disabled):hover {
  background: rgba(255,255,255,.07) !important;
  border-color: rgba(247,209,0,.3) !important;
  color: var(--rk-yellow) !important;
}

.rk-tabulator .tabulator-page.active {
  background: var(--rk-yellow) !important;
  border-color: var(--rk-yellow) !important;
  color: #111 !important;
  box-shadow: 0 7px 16px rgba(247,209,0,.16) !important;
}

.rk-tabulator .tabulator-page:disabled {
  background: rgba(255,255,255,.025) !important;
  border-color: rgba(255,255,255,.07) !important;
  color: rgba(247,248,250,.28) !important;
}

/* 테이블 바디는 헤더/푸터와 구분되도록 한 톤 낮게 유지 */
.rk-tabulator .tabulator-tableholder,
.rk-tabulator .tabulator-table {
  background: #0a0f16 !important;
}



/*
  BY JS 2026-06-05 V10 보완
  사용법:
  - V9 하단에 유지하는 Tabulator footer 최종 보정 레이어다.
  - Tabulator footer를 별도 카드처럼 보이지 않게 하고, 테이블 내부 하단바처럼 통일한다.
  - footer / footer-contents / paginator의 배경 중첩을 완전히 제거한다.
*/

/* ==========================================================================
   1. Tabulator 전체 컨테이너 라운딩 정리
   ========================================================================== */
.rk-tabulator,
.rk-tabulator.tabulator {
  border: 1px solid rgba(255,255,255,.13) !important;
  border-radius: 20px !important;
  overflow: hidden !important;
  background: #0a0f16 !important;
  box-shadow:
    0 22px 54px rgba(0,0,0,.34),
    inset 0 1px 0 rgba(255,255,255,.08) !important;
}

/* 헤더는 상단만 라운딩 */
.rk-tabulator .tabulator-header,
.rk-tabulator.tabulator .tabulator-header {
  border-radius: 19px 19px 0 0 !important;
  background:
    linear-gradient(180deg, rgba(255,255,255,.058), rgba(255,255,255,.018)),
    #101720 !important;
  border-bottom: 1px solid rgba(255,255,255,.12) !important;
  box-shadow: none !important;
}

/* 본문은 순수 다크 한 톤 */
.rk-tabulator .tabulator-tableholder,
.rk-tabulator .tabulator-table,
.rk-tabulator.tabulator .tabulator-tableholder,
.rk-tabulator.tabulator .tabulator-table {
  background: #0a0f16 !important;
  background-color: #0a0f16 !important;
}

/* ==========================================================================
   2. 하단 footer를 별도 박스가 아닌 내부 하단바로 통일
   ========================================================================== */
.rk-tabulator .tabulator-footer,
.rk-tabulator.tabulator .tabulator-footer {
  height: 38px !important;
  min-height: 38px !important;
  padding: 0 10px !important;
  border-top: 1px solid rgba(255,255,255,.105) !important;
  border-radius: 0 0 19px 19px !important;
  background:
    linear-gradient(180deg, rgba(255,255,255,.024), rgba(255,255,255,.012)),
    #0a0f16 !important;
  background-color: #0a0f16 !important;
  box-shadow: none !important;
}

/* 기존 장식 라인 제거 */
.rk-tabulator .tabulator-footer::before,
.rk-tabulator .tabulator-footer::after {
  display: none !important;
}

/* footer 내부 컨텐츠는 완전 투명 */
.rk-tabulator .tabulator-footer-contents,
.rk-tabulator .tabulator-paginator,
.rk-tabulator .tabulator-pages {
  height: 100% !important;
  background: transparent !important;
  background-color: transparent !important;
  box-shadow: none !important;
  border: 0 !important;
}

/* footer contents 정렬 */
.rk-tabulator .tabulator-footer-contents {
  display: flex !important;
  align-items: center !important;
  justify-content: flex-start !important;
  padding: 0 !important;
}

/* paginator는 좌측 하단에 낮은 높이로 배치 */
.rk-tabulator .tabulator-paginator {
  display: inline-flex !important;
  align-items: center !important;
  gap: 5px !important;
  padding: 0 !important;
  color: var(--rk-text-muted) !important;
}

.rk-tabulator .tabulator-pages {
  display: inline-flex !important;
  align-items: center !important;
  gap: 5px !important;
}

/* ==========================================================================
   3. 페이지 버튼 색상 충돌 제거
   ========================================================================== */
.rk-tabulator .tabulator-page {
  height: 26px !important;
  min-width: 28px !important;
  margin: 0 !important;
  padding: 0 8px !important;
  border-radius: 9px !important;
  border: 1px solid rgba(255,255,255,.075) !important;
  background: rgba(255,255,255,.024) !important;
  color: rgba(247,248,250,.44) !important;
  font-size: 10.5px !important;
  font-weight: 900 !important;
  line-height: 24px !important;
  box-shadow: none !important;
  transition:
    background-color 160ms var(--rk-ease-glass),
    border-color 160ms var(--rk-ease-glass),
    color 160ms var(--rk-ease-glass);
}

.rk-tabulator .tabulator-page[data-page="first"],
.rk-tabulator .tabulator-page[data-page="prev"],
.rk-tabulator .tabulator-page[data-page="next"],
.rk-tabulator .tabulator-page[data-page="last"] {
  min-width: 42px !important;
}

/* 비활성 버튼은 거의 배경에 묻히도록 */
.rk-tabulator .tabulator-page:disabled {
  background: rgba(255,255,255,.014) !important;
  border-color: rgba(255,255,255,.045) !important;
  color: rgba(247,248,250,.18) !important;
  opacity: 1 !important;
}

/* hover는 옐로우 텍스트만 */
.rk-tabulator .tabulator-page:not(.active):not(:disabled):hover {
  background: rgba(247,209,0,.065) !important;
  border-color: rgba(247,209,0,.22) !important;
  color: var(--rk-yellow) !important;
}

/* 활성 페이지만 명확하게 */
.rk-tabulator .tabulator-page.active {
  min-width: 30px !important;
  border-color: var(--rk-yellow) !important;
  background: var(--rk-yellow) !important;
  color: #111 !important;
  box-shadow: 0 6px 14px rgba(247,209,0,.16) !important;
}

/* 페이지 사이즈/카운터/불필요 텍스트 숨김 */
.rk-tabulator .tabulator-page-size,
.rk-tabulator .tabulator-footer .tabulator-page-counter,
.rk-tabulator .tabulator-footer .tabulator-paginator label {
  display: none !important;
}

/* ==========================================================================
   4. 스크롤바/하단 경계 통일
   ========================================================================== */
.rk-tabulator .tabulator-tableholder::-webkit-scrollbar {
  width: 10px;
  height: 10px;
}

.rk-tabulator .tabulator-tableholder::-webkit-scrollbar-track {
  background: #0a0f16;
}

.rk-tabulator .tabulator-tableholder::-webkit-scrollbar-thumb {
  border: 2px solid #0a0f16;
  border-radius: 999px;
  background: rgba(255,255,255,.25);
}

.rk-tabulator .tabulator-tableholder::-webkit-scrollbar-thumb:hover {
  background: rgba(247,209,0,.42);
}

/* 목록 화면에서 하단 여백 과다 방지 */
.rk-list-page-body .rk-tabulator {
  height: calc(100vh - 268px) !important;
}

.rk-list-page-body .rk-content {
  padding-bottom: 8px !important;
}

/* ==========================================================================
   5. 라운딩 내부 행이 바깥 라운딩을 침범하지 않도록 보정
   ========================================================================== */
.rk-tabulator .tabulator-row:last-child {
  border-bottom-color: rgba(255,255,255,.04) !important;
}

.rk-tabulator .tabulator-placeholder {
  background: #0a0f16 !important;
}



/*
  BY JS 2026-06-05 V11 보완
  사용법:
  - 모든 드롭다운은 .rk-select-menu 커스텀 드롭다운만 사용한다.
  - 상세검색 영역 내부 드롭다운은 .rk-filter-drawer.is-open 상태에서 overflow: visible 처리한다.
  - 드롭다운 z-index는 일반 화면 위, 상세창/모달/토스트 아래에 위치한다.
  - 푸터는 partials/footer.html 파일 기준으로 분리하고, 스티키 없이 .rk-shell 하단에 붙는 블럭으로 사용한다.
*/

/* ==========================================================================
   1. 커스텀 드롭다운 표시/레이어 보정
   ========================================================================== */
.rk-select,
select.rk-select {
  display: none !important;
}

.rk-search-panel,
.rk-filter-drawer,
.rk-filter-drawer.is-open,
.rk-field,
.rk-select-wrap,
.rk-card:has(.rk-select-menu),
.rk-search-panel:has(.rk-select-menu) {
  overflow: visible !important;
}

.rk-search-panel {
  position: relative;
  z-index: 32;
}

.rk-filter-drawer {
  position: relative;
  z-index: 33;
}

.rk-filter-drawer.is-open {
  max-height: 320px !important;
  opacity: 1 !important;
  transform: translateY(0) !important;
  padding-top: 8px !important;
  padding-bottom: 6px !important;
}

.rk-select-menu {
  position: relative !important;
  z-index: 40 !important;
  width: 100%;
  min-width: 0;
}

.rk-select-menu.is-open {
  z-index: 48 !important;
}

.rk-select-button {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 10px !important;
  width: 100% !important;
  min-width: 0 !important;
  height: 44px !important;
  padding: 0 13px !important;
  border: 1px solid rgba(255,255,255,.12) !important;
  border-radius: var(--rk-radius-md) !important;
  background:
    linear-gradient(180deg, rgba(255,255,255,.07), rgba(255,255,255,.03)),
    rgba(255,255,255,.044) !important;
  color: var(--rk-text) !important;
  font-size: 13px !important;
  font-weight: 900 !important;
  text-align: left !important;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.08),
    0 10px 24px rgba(0,0,0,.14) !important;
}

.rk-select-button [data-rk-select-label] {
  display: block;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.rk-select-arrow {
  position: relative !important;
  right: auto !important;
  top: auto !important;
  flex: 0 0 9px !important;
  width: 9px !important;
  height: 9px !important;
  margin-left: auto !important;
  border-right: 2px solid currentColor !important;
  border-bottom: 2px solid currentColor !important;
  color: var(--rk-text-muted) !important;
  transform: translateY(-2px) rotate(45deg) !important;
  transition:
    transform 240ms var(--rk-ease-glass),
    color 200ms var(--rk-ease-glass) !important;
}

.rk-select-menu.is-open .rk-select-arrow {
  color: var(--rk-yellow) !important;
  transform: translateY(2px) rotate(225deg) !important;
}

.rk-select-list {
  position: absolute !important;
  left: 0 !important;
  right: 0 !important;
  top: calc(100% + 7px) !important;
  z-index: 48 !important;
  display: block !important;
  max-height: 230px !important;
  overflow: auto !important;
  padding: 6px !important;
  border: 1px solid rgba(255,255,255,.13) !important;
  border-radius: 16px !important;
  background:
    linear-gradient(180deg, rgba(255,255,255,.09), rgba(255,255,255,.034)),
    rgba(12,17,24,.97) !important;
  box-shadow:
    0 22px 54px rgba(0,0,0,.38),
    inset 0 1px 0 rgba(255,255,255,.12) !important;
  backdrop-filter: blur(24px) saturate(1.32);
  pointer-events: none !important;
  opacity: 0 !important;
  transform: translateY(-9px) scale(.975) !important;
  transform-origin: top center !important;
  transition:
    opacity 240ms var(--rk-ease-glass),
    transform 240ms var(--rk-ease-glass) !important;
}

.rk-select-menu.is-open .rk-select-list {
  pointer-events: auto !important;
  opacity: 1 !important;
  transform: translateY(0) scale(1) !important;
}

.rk-select-option {
  display: flex !important;
  align-items: center !important;
  width: 100% !important;
  min-height: 34px !important;
  padding: 0 10px !important;
  border: 0 !important;
  border-radius: 11px !important;
  background: transparent !important;
  color: var(--rk-text-soft) !important;
  font-size: 12.5px !important;
  font-weight: 900 !important;
  text-align: left !important;
}

.rk-select-option:hover {
  background: rgba(255,255,255,.07) !important;
  color: var(--rk-text) !important;
}

.rk-select-option.is-selected {
  background:
    linear-gradient(135deg, rgba(247,209,0,.96), rgba(255,230,135,.96)) !important;
  color: #101010 !important;
}

/* 드롭다운은 모달/팝업/토스트보다 아래 */
.rk-detail-backdrop { z-index: 58 !important; }
.rk-detail-panel { z-index: 59 !important; }
.rk-modal-backdrop { z-index: 60 !important; }
.rk-toast { z-index: 80 !important; }

/* ==========================================================================
   2. 푸터 V11: 사이드바와 결이 맞는 심플 블럭
   ========================================================================== */
.rk-shell > .rk-footer {
  margin: 0 28px 24px !important;
}

.rk-footer {
  position: relative !important;
  z-index: 1;
  overflow: hidden;
  border: 1px solid rgba(255,255,255,.095) !important;
  border-radius: 18px !important;
  background:
    linear-gradient(180deg, rgba(255,255,255,.052), rgba(255,255,255,.022)),
    rgba(5, 7, 10, .62) !important;
  box-shadow:
    0 14px 32px rgba(0,0,0,.22),
    inset 0 1px 0 rgba(255,255,255,.065) !important;
  backdrop-filter: blur(18px) saturate(1.18);
}

.rk-footer::before {
  content: "";
  position: absolute;
  left: 18px;
  right: 18px;
  top: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(247,209,0,.28), transparent);
  opacity: .72;
  pointer-events: none;
}

.rk-footer__light {
  display: none !important;
}

.rk-footer__inner {
  position: relative;
  z-index: 1;
  min-height: 56px !important;
  display: grid;
  grid-template-columns: minmax(230px, .9fr) auto minmax(180px, .65fr) !important;
  align-items: center;
  gap: 14px !important;
  padding: 10px 14px !important;
}

.rk-footer-brand {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  min-width: 0;
}

.rk-footer-brand__mark {
  width: 34px !important;
  height: 34px !important;
  border: 1px solid rgba(247,209,0,.16) !important;
  border-radius: 12px !important;
  background:
    radial-gradient(circle, rgba(247,209,0,.12), transparent 68%),
    rgba(255,255,255,.035) !important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.08) !important;
}

.rk-footer-brand__mark img {
  width: 22px !important;
  height: 22px !important;
  filter:
    brightness(0) invert(1)
    drop-shadow(0 0 8px rgba(247,209,0,.28)) !important;
}

.rk-footer-brand__text strong {
  display: block;
  color: var(--rk-text);
  font-size: 11.5px !important;
  line-height: 1;
  font-weight: 900;
  letter-spacing: .1em;
  white-space: nowrap;
}

.rk-footer-brand__text em {
  display: block;
  margin-top: 5px;
  color: var(--rk-text-muted);
  font-size: 10.5px !important;
  line-height: 1;
  font-style: normal;
  font-weight: 800;
}

.rk-footer-nav {
  display: inline-flex;
  justify-content: center;
  gap: 2px !important;
  padding: 2px !important;
  border: 1px solid rgba(255,255,255,.065) !important;
  border-radius: 12px !important;
  background: rgba(255,255,255,.024) !important;
}

.rk-footer-nav a {
  min-height: 28px !important;
  display: inline-flex;
  align-items: center;
  padding: 0 10px !important;
  border-radius: 10px !important;
  color: var(--rk-text-soft);
  font-size: 10.5px !important;
  font-weight: 900;
}

.rk-footer-nav a:hover {
  background: rgba(247,209,0,.09) !important;
  color: var(--rk-yellow) !important;
}

.rk-footer-meta {
  justify-self: end;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  min-width: 0;
}

.rk-footer-state {
  min-height: 26px !important;
  padding: 0 9px !important;
  border: 1px solid rgba(247,209,0,.22) !important;
  border-radius: 999px;
  background: rgba(247,209,0,.075) !important;
  color: var(--rk-yellow);
  font-size: 10px !important;
  font-weight: 900;
  letter-spacing: .06em;
  white-space: nowrap;
}

.rk-footer-copy {
  color: var(--rk-text-muted);
  font-size: 10px !important;
  font-weight: 800;
  letter-spacing: .01em;
  white-space: nowrap;
}

/* 로그인 전용 */
.rk-footer--login {
  width: min(980px, calc(100% - 56px)) !important;
  margin: -8px auto 24px !important;
}

.rk-footer--login .rk-footer__inner {
  grid-template-columns: minmax(230px, 1fr) minmax(220px, auto) !important;
}

.rk-footer--login .rk-footer-nav {
  display: none !important;
}

/* 목록 화면에서는 푸터를 더 낮고 가까이 붙인다. */
.rk-list-page-body .rk-shell > .rk-footer {
  margin: 0 28px 14px !important;
}

.rk-list-page-body .rk-footer__inner {
  min-height: 50px !important;
  padding-top: 8px !important;
  padding-bottom: 8px !important;
}

/* 푸터는 스티키 금지 */
.rk-footer,
.rk-footer * {
  position: relative;
}

.rk-footer {
  top: auto !important;
  bottom: auto !important;
}

/* ==========================================================================
   3. 반응형
   ========================================================================== */
@media (max-width: 1180px) {
  .rk-shell > .rk-footer {
    margin: 0 16px 16px !important;
  }

  .rk-footer__inner {
    grid-template-columns: 1fr !important;
    justify-items: start;
  }

  .rk-footer-meta {
    justify-self: start;
  }
}

@media (max-width: 640px) {
  .rk-filter-drawer.is-open {
    max-height: 520px !important;
  }

  .rk-footer {
    border-radius: 16px !important;
  }

  .rk-footer-nav {
    flex-wrap: wrap;
    justify-content: flex-start;
  }

  .rk-footer-copy {
    white-space: normal;
  }
}



/*
  BY JS 2026-06-05 V12 보완
  사용법:
  - 로그인 화면 body에 .rk-login-body 클래스를 부여한다.
  - 로그인 폼에는 data-rk-login-form 속성을 부여한다.
  - 로그인 버튼에는 data-rk-login-button 속성을 부여한다.
  - 로그인 클릭 시 .rk-login-loading-overlay가 표시되며, 고급 로고 빌드 로딩을 사용한다.
*/

/* ==========================================================================
   1. 로그인 화면 진입 애니메이션
   ========================================================================== */
.rk-login-body {
  overflow-x: hidden;
}

.rk-login-body .rk-login-page {
  min-height: calc(100vh - 92px);
  perspective: 1200px;
}

.rk-login-body .rk-login-wrap {
  position: relative;
  opacity: 0;
  transform: translateY(26px) scale(.982);
  animation: rkLoginWrapInV12 900ms cubic-bezier(.16, 1, .3, 1) 80ms forwards;
}

.rk-login-body .rk-login-wrap::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 4;
  pointer-events: none;
  background:
    linear-gradient(
      105deg,
      transparent 0%,
      rgba(255,255,255,.02) 30%,
      rgba(247,209,0,.18) 48%,
      rgba(255,255,255,.12) 52%,
      transparent 70%
    );
  transform: translateX(-118%) skewX(-12deg);
  animation: rkLoginFirstLightV12 1300ms cubic-bezier(.16, 1, .3, 1) 420ms forwards;
}

.rk-login-body .rk-login-form-side {
  opacity: 0;
  transform: translateX(-18px);
  animation: rkLoginPanelInV12 760ms cubic-bezier(.16, 1, .3, 1) 280ms forwards;
}

.rk-login-body .rk-login-brand-side {
  opacity: 0;
  transform: translateX(18px);
  animation: rkLoginPanelInV12 760ms cubic-bezier(.16, 1, .3, 1) 360ms forwards;
}

.rk-login-body .rk-system-lockup,
.rk-login-body .rk-h1,
.rk-login-body .rk-form .rk-field,
.rk-login-body .rk-form .rk-check,
.rk-login-body .rk-form .rk-btn {
  opacity: 0;
  transform: translateY(14px);
  animation: rkLoginItemInV12 660ms cubic-bezier(.16, 1, .3, 1) forwards;
}

.rk-login-body .rk-system-lockup { animation-delay: 520ms; }
.rk-login-body .rk-h1 { animation-delay: 600ms; }
.rk-login-body .rk-form .rk-field:nth-of-type(1) { animation-delay: 690ms; }
.rk-login-body .rk-form .rk-field:nth-of-type(2) { animation-delay: 770ms; }
.rk-login-body .rk-form .rk-check { animation-delay: 850ms; }
.rk-login-body .rk-form .rk-btn { animation-delay: 930ms; }

.rk-login-body .rk-login-logo {
  opacity: 0;
  transform: scale(.92);
  animation: rkLoginLogoInV12 1100ms cubic-bezier(.16, 1, .3, 1) 540ms forwards;
}

.rk-login-body .rk-light-sweep::before,
.rk-login-body .rk-light-sweep::after {
  animation-duration: 7.2s !important;
}

/* ==========================================================================
   2. 로그인 버튼 로딩 상태
   ========================================================================== */
.rk-login-submit {
  position: relative;
  overflow: hidden;
}

.rk-login-submit::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(
      110deg,
      transparent 0%,
      rgba(255,255,255,.36) 45%,
      transparent 62%
    );
  transform: translateX(-118%);
  transition: transform 760ms cubic-bezier(.16, 1, .3, 1);
}

.rk-login-submit:hover::before {
  transform: translateX(118%);
}

.rk-login-submit.is-loading {
  color: transparent !important;
  pointer-events: none;
  transform: none !important;
}

.rk-login-submit.is-loading::before {
  animation: rkLoginButtonSweepV12 1.25s cubic-bezier(.45, 0, .2, 1) infinite;
}

.rk-login-submit.is-loading::after {
  content: "";
  position: absolute;
  left: 50%;
  top: 50%;
  width: 22px;
  height: 22px;
  margin: -11px 0 0 -11px;
  border-radius: 999px;
  border: 2px solid rgba(17,17,17,.24);
  border-top-color: #111;
  border-right-color: #111;
  animation: rkLoginButtonSpinV12 720ms linear infinite;
}

/* ==========================================================================
   3. 로그인 전용 로딩 오버레이
   ========================================================================== */
.rk-login-loading-overlay {
  position: fixed;
  inset: 0;
  z-index: 90;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 24px;
  background:
    radial-gradient(circle at 50% 44%, rgba(247,209,0,.12), transparent 32%),
    rgba(3,5,8,.72);
  backdrop-filter: blur(30px) saturate(1.28);
  opacity: 0;
  pointer-events: none;
  transition:
    opacity 320ms cubic-bezier(.16, 1, .3, 1);
}

.rk-login-loading-overlay.is-visible {
  opacity: 1;
  pointer-events: auto;
}

.rk-login-loading-card {
  position: relative;
  width: min(360px, 100%);
  min-height: 300px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 28px;
  background:
    linear-gradient(180deg, rgba(255,255,255,.082), rgba(255,255,255,.032)),
    rgba(13, 18, 25, .84);
  box-shadow:
    0 34px 96px rgba(0,0,0,.48),
    inset 0 1px 0 rgba(255,255,255,.09);
  backdrop-filter: blur(28px) saturate(1.32);
  overflow: visible;
  transform: translateY(18px) scale(.975);
  opacity: 0;
  transition:
    opacity 420ms cubic-bezier(.16, 1, .3, 1),
    transform 420ms cubic-bezier(.16, 1, .3, 1);
}

.rk-login-loading-overlay.is-visible .rk-login-loading-card {
  opacity: 1;
  transform: translateY(0) scale(1);
}

.rk-login-loading-card::before {
  content: "";
  position: absolute;
  inset: -44px;
  z-index: -1;
  border-radius: 38px;
  background:
    radial-gradient(circle at 50% 46%, rgba(247,209,0,.16), transparent 34%),
    radial-gradient(circle at 50% 62%, rgba(247,209,0,.06), transparent 38%);
  filter: blur(22px);
  pointer-events: none;
}

.rk-login-loading-card::after {
  content: "";
  position: absolute;
  left: 22px;
  right: 22px;
  top: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(247,209,0,.52), transparent);
  filter: drop-shadow(0 0 12px rgba(247,209,0,.28));
}

.rk-login-loading-title {
  margin: 24px 0 0;
  color: var(--rk-text);
  font-size: 16px;
  font-weight: 900;
  letter-spacing: -.02em;
}

.rk-login-loading-desc {
  margin: 8px 0 0;
  color: var(--rk-text-muted);
  font-size: 12px;
  font-weight: 800;
}

.rk-login-loading-progress {
  position: relative;
  overflow: hidden;
  width: 210px;
  height: 4px;
  margin-top: 22px;
  border-radius: 999px;
  background: rgba(255,255,255,.07);
}

.rk-login-loading-progress::before {
  content: "";
  position: absolute;
  left: -35%;
  top: 0;
  width: 38%;
  height: 100%;
  border-radius: inherit;
  background:
    linear-gradient(90deg, transparent, var(--rk-yellow), rgba(255,255,255,.45), transparent);
  filter: drop-shadow(0 0 12px rgba(247,209,0,.52));
  animation: rkLoginProgressV12 1.65s cubic-bezier(.45, 0, .2, 1) infinite;
}

/* 오버레이 내부 로고 로딩은 조금 더 작게 정리 */
.rk-login-loading-card .rk-logo-loader {
  width: 148px !important;
  height: 148px !important;
}

.rk-login-loading-card .rk-logo-edge {
  width: 100px !important;
  height: 100px !important;
}

.rk-login-loading-card .rk-logo-loader img {
  width: 92px !important;
}

/* ==========================================================================
   4. 로그인 푸터 등장
   ========================================================================== */
.rk-login-body .rk-footer--login {
  opacity: 0;
  transform: translateY(16px);
  animation: rkLoginItemInV12 700ms cubic-bezier(.16, 1, .3, 1) 980ms forwards;
}

/* ==========================================================================
   5. 키프레임
   ========================================================================== */
@keyframes rkLoginWrapInV12 {
  to {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}

@keyframes rkLoginFirstLightV12 {
  to {
    transform: translateX(118%) skewX(-12deg);
  }
}

@keyframes rkLoginPanelInV12 {
  to {
    opacity: 1;
    transform: translateX(0);
  }
}

@keyframes rkLoginItemInV12 {
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes rkLoginLogoInV12 {
  0% {
    opacity: 0;
    transform: scale(.92);
    filter:
      brightness(0) invert(1)
      drop-shadow(0 0 0 rgba(247,209,0,0));
  }
  60% {
    opacity: 1;
    transform: scale(1.04);
    filter:
      brightness(0) invert(1)
      drop-shadow(0 0 16px rgba(247,209,0,.44))
      drop-shadow(0 0 48px rgba(247,209,0,.18));
  }
  100% {
    opacity: 1;
    transform: scale(1);
  }
}

@keyframes rkLoginButtonSweepV12 {
  0% {
    transform: translateX(-118%);
  }
  100% {
    transform: translateX(118%);
  }
}

@keyframes rkLoginButtonSpinV12 {
  to {
    transform: rotate(360deg);
  }
}

@keyframes rkLoginProgressV12 {
  0% {
    left: -35%;
    opacity: 0;
  }
  18% {
    opacity: 1;
  }
  100% {
    left: 100%;
    opacity: 0;
  }
}

/* ==========================================================================
   6. 접근성/모바일
   ========================================================================== */
@media (prefers-reduced-motion: reduce) {
  .rk-login-body .rk-login-wrap,
  .rk-login-body .rk-login-form-side,
  .rk-login-body .rk-login-brand-side,
  .rk-login-body .rk-system-lockup,
  .rk-login-body .rk-h1,
  .rk-login-body .rk-form .rk-field,
  .rk-login-body .rk-form .rk-check,
  .rk-login-body .rk-form .rk-btn,
  .rk-login-body .rk-login-logo,
  .rk-login-body .rk-footer--login {
    opacity: 1 !important;
    transform: none !important;
    animation: none !important;
  }
}

@media (max-width: 760px) {
  .rk-login-body .rk-login-page {
    min-height: auto;
  }

  .rk-login-loading-card {
    min-height: 280px;
  }
}



/*
  BY JS 2026-06-05 V13 보완
  사용법:
  - 로그인 화면은 버튼 내부 로딩도 로고 로딩 결로 통일한다.
  - 로그인 페이지 푸터는 제거한다.
  - 일반 페이지 푸터는 .rk-shell 하단 전체 폭의 라운드 없는 블럭으로 사용한다.
  - Tabulator pagination은 오른쪽 정렬한다.
  - 커스텀 드롭다운은 Tabulator보다 위, 상세창/모달/토스트보다 아래에 표시한다.
*/

/* ==========================================================================
   1. 로그인 버튼 로고 로딩
   ========================================================================== */
.rk-login-submit {
  --rk-login-btn-logo-size: 22px;
}

.rk-login-submit.is-loading {
  color: transparent !important;
}

.rk-login-submit.is-loading::after {
  display: none !important;
}

.rk-login-submit .rk-login-button-logo {
  position: absolute;
  left: 50%;
  top: 50%;
  width: var(--rk-login-btn-logo-size);
  height: var(--rk-login-btn-logo-size);
  opacity: 0;
  transform: translate(-50%, -50%) scale(.88);
  pointer-events: none;
}

.rk-login-submit .rk-login-button-logo img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: contain;
  filter:
    brightness(0)
    drop-shadow(0 0 5px rgba(17,17,17,.28));
}

.rk-login-submit .rk-login-button-logo::before {
  content: "";
  position: absolute;
  inset: -7px;
  border-radius: 999px;
  background:
    radial-gradient(circle, rgba(17,17,17,.12), transparent 58%);
  opacity: 0;
}

.rk-login-submit.is-loading .rk-login-button-logo {
  opacity: 1;
  animation: rkLoginButtonLogoV13 1.45s cubic-bezier(.45, 0, .2, 1) infinite;
}

.rk-login-submit.is-loading .rk-login-button-logo::before {
  opacity: 1;
  animation: rkLoginButtonLogoGlowV13 1.45s cubic-bezier(.45, 0, .2, 1) infinite;
}

@keyframes rkLoginButtonLogoV13 {
  0%, 100% {
    transform: translate(-50%, -50%) scale(.9);
    opacity: .72;
  }
  48% {
    transform: translate(-50%, -50%) scale(1.14);
    opacity: 1;
  }
}

@keyframes rkLoginButtonLogoGlowV13 {
  0%, 100% {
    transform: scale(.82);
    opacity: .18;
  }
  48% {
    transform: scale(1.18);
    opacity: .48;
  }
}

/* ==========================================================================
   2. 로그인 페이지 푸터 제거
   ========================================================================== */
.rk-login-body .rk-footer,
.rk-login-body .rk-footer--login {
  display: none !important;
}

/* ==========================================================================
   3. 푸터 V13: 하단 전체 폭 / 라운드 없는 한 블럭
   ========================================================================== */
.rk-shell > .rk-footer {
  width: 100% !important;
  margin: 0 !important;
}

.rk-footer {
  border-left: 0 !important;
  border-right: 0 !important;
  border-bottom: 0 !important;
  border-radius: 0 !important;
  background:
    linear-gradient(180deg, rgba(255,255,255,.045), rgba(255,255,255,.018)),
    rgba(5, 7, 10, .72) !important;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.07),
    0 -12px 28px rgba(0,0,0,.16) !important;
}

.rk-footer::before {
  left: 0 !important;
  right: 0 !important;
  background: linear-gradient(90deg, rgba(247,209,0,.18), rgba(255,255,255,.06), rgba(247,209,0,.18)) !important;
}

.rk-footer__inner {
  min-height: 58px !important;
  padding: 10px 28px !important;
}

.rk-list-page-body .rk-shell > .rk-footer {
  margin: 0 !important;
}

.rk-list-page-body .rk-footer__inner {
  min-height: 52px !important;
  padding-top: 8px !important;
  padding-bottom: 8px !important;
}

/* ==========================================================================
   4. Tabulator pagination 오른쪽 정렬
   ========================================================================== */
.rk-tabulator .tabulator-footer-contents {
  justify-content: flex-end !important;
}

.rk-tabulator .tabulator-paginator {
  margin-left: auto !important;
  justify-content: flex-end !important;
}

/* ==========================================================================
   5. 커스텀 드롭다운이 Tabulator에 가리는 문제 보정
   ========================================================================== */
.rk-content,
.rk-stack,
.rk-section,
.rk-card,
.rk-search-panel,
.rk-filter-drawer,
.rk-filter-drawer.is-open,
.rk-field,
.rk-select-wrap {
  overflow: visible !important;
}

.rk-section:has(.rk-search-panel) {
  position: relative;
  z-index: 54 !important;
}

.rk-section:has(.rk-tabulator) {
  position: relative;
  z-index: 5 !important;
}

.rk-search-panel {
  position: relative;
  z-index: 54 !important;
}

.rk-filter-drawer,
.rk-filter-drawer.is-open {
  position: relative;
  z-index: 55 !important;
}

.rk-select-menu {
  position: relative !important;
  z-index: 55 !important;
}

.rk-select-menu.is-open {
  z-index: 56 !important;
}

.rk-select-list {
  z-index: 56 !important;
}

/* 상세창/모달/토스트는 드롭다운보다 위 */
.rk-detail-backdrop { z-index: 58 !important; }
.rk-detail-panel { z-index: 59 !important; }
.rk-modal-backdrop { z-index: 60 !important; }
.rk-toast { z-index: 80 !important; }

/* Tabulator는 드롭다운보다 아래 */
.rk-tabulator,
.rk-tabulator.tabulator {
  position: relative !important;
  z-index: 1 !important;
}

/* 목록 화면 상세검색 드롭다운 높이 확보 */
.rk-filter-drawer.is-open {
  max-height: 360px !important;
}

/* ==========================================================================
   6. 모바일 보정
   ========================================================================== */
@media (max-width: 1180px) {
  .rk-footer__inner {
    padding-left: 16px !important;
    padding-right: 16px !important;
  }
}

@media (max-width: 760px) {
  .rk-footer__inner {
    grid-template-columns: 1fr !important;
    gap: 10px !important;
  }

  .rk-filter-drawer.is-open {
    max-height: 540px !important;
  }
}



/*
  BY JS 2026-06-05 V14 보완
  사용법:
  - 모든 리퀴드 글라스 카드의 노란 글로우는 카드 라운드와 동일한 radius를 따른다.
  - 커스텀 드롭다운은 기존 카드 내부 list가 아니라 body에 붙는 .rk-select-portal로 표시한다.
  - .rk-select-portal은 Tabulator보다 위, 상세창/모달/토스트보다 아래에 위치한다.
  - 단위가 필요한 입력은 반드시 .rk-unit-field 안에 input + .rk-unit 구조로 작성한다.
*/

/* ==========================================================================
   1. 리퀴드 글라스 카드 라운드/그림자 정합성 보정
   ========================================================================== */
.rk-card,
.rk-search-panel,
.rk-mini-summary,
.rk-stat,
.rk-modal,
.rk-detail-panel,
.rk-loader-card,
.rk-login-wrap,
.rk-login-loading-card,
.rk-tabulator,
.rk-dropzone,
.rk-empty,
.rk-list-item,
.rk-step,
.rk-alert {
  position: relative !important;
  isolation: isolate !important;
  background-clip: padding-box !important;
}

/* 기존 pseudo glow가 사각형으로 깔리는 문제 방지 */
.rk-card::before,
.rk-card::after,
.rk-search-panel::before,
.rk-search-panel::after,
.rk-mini-summary::before,
.rk-mini-summary::after,
.rk-stat::before,
.rk-stat::after,
.rk-modal::before,
.rk-modal::after,
.rk-detail-panel::before,
.rk-detail-panel::after,
.rk-loader-card::before,
.rk-loader-card::after,
.rk-login-wrap::before,
.rk-login-wrap::after,
.rk-login-loading-card::before,
.rk-login-loading-card::after,
.rk-tabulator::before,
.rk-tabulator::after,
.rk-dropzone::before,
.rk-dropzone::after,
.rk-empty::before,
.rk-empty::after,
.rk-list-item::before,
.rk-list-item::after,
.rk-step::before,
.rk-step::after,
.rk-alert::before,
.rk-alert::after {
  border-radius: inherit !important;
}

/* 카드 외부 노란 사각 glow 대신 내부 라운드 광택만 유지 */
.rk-card,
.rk-search-panel,
.rk-mini-summary,
.rk-stat,
.rk-modal,
.rk-detail-panel,
.rk-loader-card,
.rk-login-wrap,
.rk-login-loading-card {
  box-shadow:
    0 22px 54px rgba(0, 0, 0, .32),
    inset 0 1px 0 rgba(255, 255, 255, .09) !important;
}

.rk-card::before,
.rk-search-panel::before,
.rk-mini-summary::before,
.rk-stat::before {
  overflow: hidden !important;
  background:
    radial-gradient(120% 90% at 12% 0%, rgba(247, 209, 0, .065), transparent 44%),
    linear-gradient(180deg, rgba(255,255,255,.066), rgba(255,255,255,.024)) !important;
  opacity: .86 !important;
}

/* 라운드 카드 아래 노란 빛이 모서리에서 각지지 않도록 inset ring 방식 사용 */
.rk-card::after,
.rk-search-panel::after,
.rk-mini-summary::after,
.rk-stat::after {
  content: "" !important;
  position: absolute !important;
  inset: 0 !important;
  pointer-events: none !important;
  z-index: 0 !important;
  border: 1px solid rgba(247, 209, 0, .045) !important;
  border-radius: inherit !important;
  background:
    radial-gradient(80% 55% at 50% -12%, rgba(247, 209, 0, .055), transparent 58%) !important;
}

.rk-card > *,
.rk-search-panel > *,
.rk-mini-summary > *,
.rk-stat > * {
  position: relative;
  z-index: 1;
}

/* 로딩 카드/로고처럼 외부 glow가 필요한 곳은 radius가 큰 blur 레이어로 처리 */
.rk-loader-card::before,
.rk-login-loading-card::before {
  border-radius: 42px !important;
  background:
    radial-gradient(circle at 50% 46%, rgba(247,209,0,.12), transparent 34%),
    radial-gradient(circle at 50% 62%, rgba(247,209,0,.045), transparent 40%) !important;
  filter: blur(20px) !important;
}

/* ==========================================================================
   2. 단위 입력 기본 정렬 보정
   ========================================================================== */
.rk-unit-field {
  position: relative !important;
  width: 100%;
}

.rk-unit-field .rk-input {
  padding-right: 62px !important;
  text-align: right;
  font-variant-numeric: tabular-nums;
}

.rk-unit {
  position: absolute !important;
  right: 13px !important;
  top: 50% !important;
  min-width: 26px;
  text-align: right;
  transform: translateY(-50%) !important;
  color: var(--rk-text-muted) !important;
  font-size: 12px !important;
  font-weight: 900 !important;
  pointer-events: none;
}

/* ==========================================================================
   3. 드롭다운 Portal 방식
   사용법:
   - 기존 .rk-select-menu 내부 .rk-select-list는 시각적으로 사용하지 않는다.
   - JS가 body 하단에 .rk-select-portal을 만들고 fixed 위치로 표시한다.
   ========================================================================== */
.rk-select-menu {
  position: relative !important;
  z-index: 10 !important;
}

.rk-select-menu .rk-select-list,
.rk-select-menu.is-open .rk-select-list {
  display: none !important;
  opacity: 0 !important;
  pointer-events: none !important;
}

/* 드롭다운 버튼 자체는 카드 내부에 남기되, 목록은 portal로 분리한다. */
.rk-select-button {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 10px !important;
  width: 100% !important;
  min-width: 0 !important;
  padding: 0 13px !important;
}

.rk-select-button [data-rk-select-label] {
  display: block;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.rk-select-arrow {
  position: relative !important;
  right: auto !important;
  top: auto !important;
  flex: 0 0 9px !important;
  width: 9px !important;
  height: 9px !important;
  margin-left: auto !important;
  transform: translateY(-2px) rotate(45deg) !important;
}

.rk-select-menu.is-open .rk-select-arrow {
  transform: translateY(2px) rotate(225deg) !important;
}

/* 실제 표시되는 드롭다운 목록 */
.rk-select-portal {
  position: fixed;
  left: 0;
  top: 0;
  z-index: 57;
  display: none;
  min-width: 180px;
  max-height: min(280px, calc(100vh - 32px));
  overflow: auto;
  padding: 6px;
  border: 1px solid rgba(255,255,255,.14);
  border-radius: 16px;
  background:
    linear-gradient(180deg, rgba(255,255,255,.1), rgba(255,255,255,.034)),
    rgba(12,17,24,.98);
  box-shadow:
    0 24px 60px rgba(0,0,0,.44),
    inset 0 1px 0 rgba(255,255,255,.13);
  backdrop-filter: blur(26px) saturate(1.34);
  transform: translateY(-8px) scale(.98);
  transform-origin: top center;
  opacity: 0;
  pointer-events: none;
  transition:
    opacity 220ms var(--rk-ease-glass),
    transform 220ms var(--rk-ease-glass);
}

.rk-select-portal.is-visible {
  display: block;
  opacity: 1;
  pointer-events: auto;
  transform: translateY(0) scale(1);
}

.rk-select-portal.is-above {
  transform-origin: bottom center;
}

.rk-select-portal__option {
  display: flex;
  align-items: center;
  width: 100%;
  min-height: 34px;
  padding: 0 10px;
  border: 0;
  border-radius: 11px;
  background: transparent;
  color: var(--rk-text-soft);
  font-size: 12.5px;
  font-weight: 900;
  text-align: left;
  cursor: pointer;
  transition:
    background-color 160ms var(--rk-ease-glass),
    color 160ms var(--rk-ease-glass);
}

.rk-select-portal__option:hover {
  background: rgba(255,255,255,.075);
  color: var(--rk-text);
}

.rk-select-portal__option.is-selected {
  background:
    linear-gradient(135deg, rgba(247,209,0,.96), rgba(255,230,135,.96));
  color: #101010;
  box-shadow:
    0 9px 20px rgba(247,209,0,.16),
    inset 0 1px 0 rgba(255,255,255,.42);
}

/* 레이어 정책: 드롭다운은 Tabulator 위, 상세창/모달/토스트 아래 */
.rk-tabulator,
.rk-tabulator.tabulator {
  position: relative !important;
  z-index: 1 !important;
}

.rk-detail-backdrop { z-index: 58 !important; }
.rk-detail-panel { z-index: 59 !important; }
.rk-modal-backdrop { z-index: 60 !important; }
.rk-toast { z-index: 80 !important; }

/* 드롭다운이 필요한 영역은 clipping 금지 */
.rk-content,
.rk-shell,
.rk-stack,
.rk-section,
.rk-card,
.rk-search-panel,
.rk-filter-drawer,
.rk-field,
.rk-select-wrap {
  overflow: visible !important;
}

/* ==========================================================================
   4. 상세검색 카드/입력화면 드롭다운 가림 방지
   ========================================================================== */
.rk-section:has(.rk-search-panel),
.rk-search-panel,
.rk-filter-drawer,
.rk-filter-drawer.is-open {
  position: relative !important;
  z-index: 54 !important;
  overflow: visible !important;
}

.rk-section:has(.rk-tabulator) {
  position: relative !important;
  z-index: 2 !important;
}

.rk-filter-drawer.is-open {
  max-height: 420px !important;
  overflow: visible !important;
}

/* ==========================================================================
   5. 모바일 보정
   ========================================================================== */
@media (max-width: 760px) {
  .rk-select-portal {
    max-width: calc(100vw - 24px);
  }

  .rk-filter-drawer.is-open {
    max-height: 620px !important;
  }
}



/*
  BY JS 2026-06-05 V15 보완
  사용법:
  - 본 블록은 V14 위에 얹는 마감 보정 레이어다.
  - 드롭다운 화살표 정렬, 드롭다운 Portal 애니메이션, 상세창 열기, 푸터 단색 블럭, 카드 투명도 조정을 담당한다.
*/

/* ==========================================================================
   1. 리퀴드 글라스 카드 투명도 및 glow 각짐 보정
   ========================================================================== */
.rk-card,
.rk-search-panel,
.rk-mini-summary,
.rk-stat,
.rk-modal,
.rk-detail-panel,
.rk-loader-card,
.rk-login-wrap,
.rk-login-loading-card {
  background:
    linear-gradient(180deg, rgba(255,255,255,.072), rgba(255,255,255,.022)),
    rgba(10, 15, 22, .52) !important;
  border-color: rgba(255,255,255,.13) !important;
  box-shadow:
    0 18px 46px rgba(0, 0, 0, .28),
    inset 0 1px 0 rgba(255, 255, 255, .1) !important;
  backdrop-filter: blur(28px) saturate(1.34) !important;
  background-clip: padding-box !important;
  isolation: isolate !important;
}

.rk-card::before,
.rk-card::after,
.rk-search-panel::before,
.rk-search-panel::after,
.rk-mini-summary::before,
.rk-mini-summary::after,
.rk-stat::before,
.rk-stat::after,
.rk-modal::before,
.rk-modal::after,
.rk-detail-panel::before,
.rk-detail-panel::after {
  border-radius: inherit !important;
}

.rk-card::before,
.rk-search-panel::before,
.rk-mini-summary::before,
.rk-stat::before {
  background:
    radial-gradient(90% 65% at 50% -18%, rgba(247,209,0,.06), transparent 56%),
    linear-gradient(180deg, rgba(255,255,255,.07), rgba(255,255,255,.02)) !important;
  opacity: .78 !important;
}

.rk-card::after,
.rk-search-panel::after,
.rk-mini-summary::after,
.rk-stat::after {
  border-radius: inherit !important;
  background:
    radial-gradient(70% 48% at 50% 0%, rgba(247,209,0,.048), transparent 62%) !important;
  box-shadow: inset 0 0 0 1px rgba(247,209,0,.035) !important;
}

/* ==========================================================================
   2. 드롭다운 화살표 위치 정렬
   사용법:
   - .rk-select-arrow 자체에는 border를 주지 않는다.
   - ::before를 중앙 정렬한 뒤 회전시켜 모든 크기에서 위치가 일정하게 보이게 한다.
   ========================================================================== */
.rk-select-button {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 10px !important;
  height: 44px !important;
  padding: 0 12px 0 13px !important;
  line-height: 1 !important;
}

.rk-compact-page .rk-select-button {
  height: var(--rk-form-row-v4) !important;
}

.rk-select-button [data-rk-select-label] {
  flex: 1 1 auto;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.rk-select-arrow {
  position: relative !important;
  right: auto !important;
  top: auto !important;
  flex: 0 0 18px !important;
  width: 18px !important;
  height: 18px !important;
  margin-left: auto !important;
  border: 0 !important;
  color: var(--rk-text-muted) !important;
  transform: none !important;
}

.rk-select-arrow::before {
  content: "";
  position: absolute;
  left: 50%;
  top: 50%;
  width: 7px;
  height: 7px;
  border-right: 2px solid currentColor;
  border-bottom: 2px solid currentColor;
  transform: translate(-50%, -64%) rotate(45deg);
  transition:
    transform 240ms var(--rk-ease-glass),
    color 200ms var(--rk-ease-glass);
}

.rk-select-menu.is-open .rk-select-arrow {
  color: var(--rk-yellow) !important;
  transform: none !important;
}

.rk-select-menu.is-open .rk-select-arrow::before {
  transform: translate(-50%, -36%) rotate(225deg);
}

/* ==========================================================================
   3. 드롭다운 Portal 애니메이션 및 레이어 최종 보정
   ========================================================================== */
.rk-select-menu .rk-select-list,
.rk-select-menu.is-open .rk-select-list {
  display: none !important;
  opacity: 0 !important;
  pointer-events: none !important;
}

.rk-select-portal {
  position: fixed;
  left: 0;
  top: 0;
  z-index: 1500;
  display: block !important;
  visibility: hidden;
  min-width: 180px;
  max-height: min(280px, calc(100vh - 32px));
  overflow: auto;
  padding: 6px;
  border: 1px solid rgba(255,255,255,.14);
  border-radius: 16px;
  background:
    linear-gradient(180deg, rgba(255,255,255,.105), rgba(255,255,255,.036)),
    rgba(12,17,24,.985);
  box-shadow:
    0 24px 60px rgba(0,0,0,.44),
    inset 0 1px 0 rgba(255,255,255,.13);
  backdrop-filter: blur(28px) saturate(1.36);
  opacity: 0;
  pointer-events: none;
  transform: translateY(-10px) scale(.975);
  transform-origin: top center;
  transition:
    opacity 260ms var(--rk-ease-glass),
    transform 260ms var(--rk-ease-glass),
    visibility 0s linear 260ms;
}

.rk-select-portal.is-visible {
  visibility: visible;
  opacity: 1;
  pointer-events: auto;
  transform: translateY(0) scale(1);
  transition:
    opacity 260ms var(--rk-ease-glass),
    transform 260ms var(--rk-ease-glass),
    visibility 0s;
}

.rk-select-portal.is-above {
  transform-origin: bottom center;
}

.rk-select-portal.is-above:not(.is-visible) {
  transform: translateY(10px) scale(.975);
}

.rk-select-portal__option {
  display: flex;
  align-items: center;
  width: 100%;
  min-height: 34px;
  padding: 0 10px;
  border: 0;
  border-radius: 11px;
  background: transparent;
  color: var(--rk-text-soft);
  font-size: 12.5px;
  font-weight: 900;
  text-align: left;
  cursor: pointer;
  transition:
    background-color 160ms var(--rk-ease-glass),
    color 160ms var(--rk-ease-glass),
    transform 160ms var(--rk-ease-glass);
}

.rk-select-portal__option:hover {
  background: rgba(255,255,255,.075);
  color: var(--rk-text);
}

.rk-select-portal__option.is-selected {
  background:
    linear-gradient(135deg, rgba(247,209,0,.96), rgba(255,230,135,.96));
  color: #101010;
  box-shadow:
    0 9px 20px rgba(247,209,0,.16),
    inset 0 1px 0 rgba(255,255,255,.42);
}

/* 레이어 정책 */
.rk-tabulator,
.rk-tabulator.tabulator {
  position: relative !important;
  z-index: 1 !important;
}

.rk-detail-backdrop { z-index: 1900 !important; }
.rk-detail-panel { z-index: 1910 !important; }
.rk-modal-backdrop { z-index: 2000 !important; }
.rk-toast { z-index: 3000 !important; }

.rk-content,
.rk-shell,
.rk-stack,
.rk-section,
.rk-card,
.rk-search-panel,
.rk-filter-drawer,
.rk-field,
.rk-select-wrap {
  overflow: visible !important;
}

.rk-section:has(.rk-search-panel),
.rk-search-panel,
.rk-filter-drawer,
.rk-filter-drawer.is-open {
  position: relative !important;
  z-index: 120 !important;
  overflow: visible !important;
}

.rk-section:has(.rk-tabulator) {
  position: relative !important;
  z-index: 2 !important;
}

/* ==========================================================================
   4. 상세창 동작 보정
   ========================================================================== */
.rk-detail-backdrop.is-visible {
  display: block !important;
}

.rk-detail-panel.is-visible {
  opacity: 1 !important;
  pointer-events: auto !important;
  transform: translateX(0) scale(1) !important;
}

/* ==========================================================================
   5. 푸터 V15: 단색 / 메뉴 없음 / 로고 케이스 없음 / 전체 폭
   ========================================================================== */
.rk-shell > .rk-footer {
  width: 100% !important;
  margin: 0 !important;
}

.rk-footer {
  position: relative !important;
  z-index: 1;
  border: 0 !important;
  border-top: 1px solid rgba(255,255,255,.09) !important;
  border-radius: 0 !important;
  background: #070b10 !important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.04) !important;
  backdrop-filter: none !important;
}

.rk-footer::before,
.rk-footer::after,
.rk-footer__light {
  display: none !important;
}

.rk-footer__inner {
  min-height: 50px !important;
  display: grid !important;
  grid-template-columns: minmax(220px, 1fr) auto !important;
  align-items: center !important;
  gap: 14px !important;
  padding: 8px 28px !important;
}

.rk-footer-brand {
  display: inline-flex !important;
  align-items: center !important;
  gap: 10px !important;
  min-width: 0;
}

.rk-footer-brand__mark,
.rk-footer-nav {
  display: none !important;
}

.rk-footer-brand__logo {
  display: block !important;
  width: 24px !important;
  height: 24px !important;
  object-fit: contain !important;
  filter:
    brightness(0) invert(1)
    drop-shadow(0 0 8px rgba(247,209,0,.28)) !important;
}

.rk-footer-brand__text strong {
  display: block;
  color: var(--rk-text);
  font-size: 11.5px !important;
  line-height: 1;
  font-weight: 900;
  letter-spacing: .1em;
  white-space: nowrap;
}

.rk-footer-brand__text em {
  display: block;
  margin-top: 5px;
  color: var(--rk-text-muted);
  font-size: 10.5px !important;
  line-height: 1;
  font-style: normal;
  font-weight: 800;
}

.rk-footer-meta {
  justify-self: end !important;
  display: inline-flex !important;
  align-items: center !important;
  gap: 8px !important;
}

.rk-footer-state {
  min-height: 24px !important;
  padding: 0 9px !important;
  border: 1px solid rgba(247,209,0,.2) !important;
  border-radius: 999px !important;
  background: rgba(247,209,0,.07) !important;
  color: var(--rk-yellow) !important;
  font-size: 10px !important;
  font-weight: 900 !important;
  letter-spacing: .06em;
  white-space: nowrap;
}

.rk-footer-copy {
  color: var(--rk-text-muted) !important;
  font-size: 10px !important;
  font-weight: 800 !important;
  white-space: nowrap;
}

.rk-login-body .rk-footer,
.rk-login-body .rk-footer--login {
  display: none !important;
}

@media (max-width: 760px) {
  .rk-footer__inner {
    grid-template-columns: 1fr !important;
    gap: 8px !important;
    padding: 10px 16px !important;
  }

  .rk-footer-meta {
    justify-self: start !important;
    flex-wrap: wrap;
  }

  .rk-footer-copy {
    white-space: normal;
  }
}



/*
  BY JS 2026-06-05 V16 보완
  사용법:
  - V15까지 누적된 충돌을 최종 보정한다.
  - 드롭다운 화살표는 모든 위치에서 동일한 구조와 애니메이션을 사용한다.
  - 드롭다운 목록은 body portal로만 표시한다.
  - 상세창은 반드시 fixed 레이어로 표시한다.
  - 페이지 하단 빈공간을 줄이고 푸터는 shell 내부 하단 블럭으로 붙인다.
  - 텍스트 드래그 선택색은 르노 옐로우로 통일한다.
*/

/* ==========================================================================
   0. 텍스트 선택색
   ========================================================================== */
::selection {
  background: rgba(247, 209, 0, .92);
  color: #101010;
}

::-moz-selection {
  background: rgba(247, 209, 0, .92);
  color: #101010;
}

/* ==========================================================================
   1. 페이지 하단 빈공간/푸터 흐름 정리
   ========================================================================== */
.rk-app {
  min-height: 100vh !important;
}

.rk-shell {
  min-height: 100vh !important;
  display: flex !important;
  flex-direction: column !important;
}

.rk-content {
  flex: 1 0 auto !important;
  padding-bottom: 16px !important;
}

.rk-list-page-body .rk-content {
  padding-bottom: 8px !important;
}

.rk-shell > .rk-footer {
  flex: 0 0 auto !important;
  width: 100% !important;
  margin: 0 !important;
}

.rk-footer {
  position: relative !important;
  z-index: 1 !important;
  border: 0 !important;
  border-top: 1px solid rgba(255,255,255,.09) !important;
  border-radius: 0 !important;
  background: #070b10 !important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.04) !important;
  backdrop-filter: none !important;
}

.rk-footer::before,
.rk-footer::after,
.rk-footer__light {
  display: none !important;
}

.rk-footer__inner {
  min-height: 48px !important;
  display: grid !important;
  grid-template-columns: minmax(220px, 1fr) auto !important;
  align-items: center !important;
  gap: 14px !important;
  padding: 8px 28px !important;
}

.rk-footer-nav,
.rk-footer-brand__mark {
  display: none !important;
}

.rk-footer-brand {
  display: inline-flex !important;
  align-items: center !important;
  gap: 10px !important;
  min-width: 0 !important;
}

.rk-footer-brand__logo {
  display: block !important;
  width: 24px !important;
  height: 24px !important;
  object-fit: contain !important;
  filter:
    brightness(0) invert(1)
    drop-shadow(0 0 8px rgba(247,209,0,.28)) !important;
}

.rk-footer-brand__text strong {
  display: block !important;
  color: var(--rk-text) !important;
  font-size: 11.5px !important;
  line-height: 1 !important;
  font-weight: 900 !important;
  letter-spacing: .1em !important;
  white-space: nowrap !important;
}

.rk-footer-brand__text em {
  display: block !important;
  margin-top: 5px !important;
  color: var(--rk-text-muted) !important;
  font-size: 10.5px !important;
  line-height: 1 !important;
  font-style: normal !important;
  font-weight: 800 !important;
}

.rk-footer-meta {
  justify-self: end !important;
  display: inline-flex !important;
  align-items: center !important;
  gap: 8px !important;
}

.rk-login-body .rk-footer,
.rk-login-body .rk-footer--login {
  display: none !important;
}

/* ==========================================================================
   2. 리퀴드 글라스 투명도/라운드 glow 최종 보정
   ========================================================================== */
.rk-card,
.rk-search-panel,
.rk-mini-summary,
.rk-stat,
.rk-modal,
.rk-loader-card,
.rk-login-wrap,
.rk-login-loading-card {
  background:
    linear-gradient(180deg, rgba(255,255,255,.074), rgba(255,255,255,.02)),
    rgba(10, 15, 22, .50) !important;
  border-color: rgba(255,255,255,.13) !important;
  box-shadow:
    0 18px 46px rgba(0, 0, 0, .28),
    inset 0 1px 0 rgba(255, 255, 255, .1) !important;
  backdrop-filter: blur(28px) saturate(1.34) !important;
  background-clip: padding-box !important;
  isolation: isolate !important;
}

.rk-card::before,
.rk-card::after,
.rk-search-panel::before,
.rk-search-panel::after,
.rk-mini-summary::before,
.rk-mini-summary::after,
.rk-stat::before,
.rk-stat::after {
  border-radius: inherit !important;
}

.rk-card::after,
.rk-search-panel::after,
.rk-mini-summary::after,
.rk-stat::after {
  box-shadow: inset 0 0 0 1px rgba(247,209,0,.035) !important;
  background:
    radial-gradient(70% 48% at 50% 0%, rgba(247,209,0,.045), transparent 62%) !important;
}

/* ==========================================================================
   3. 드롭다운 화살표 정렬 최종
   ========================================================================== */
.rk-select-button {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 10px !important;
  height: 44px !important;
  padding: 0 12px 0 13px !important;
  line-height: 1 !important;
}

.rk-compact-page .rk-select-button {
  height: var(--rk-form-row-v4) !important;
}

.rk-select-button [data-rk-select-label] {
  flex: 1 1 auto !important;
  min-width: 0 !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  white-space: nowrap !important;
}

.rk-select-arrow {
  position: relative !important;
  right: auto !important;
  top: auto !important;
  flex: 0 0 18px !important;
  width: 18px !important;
  height: 18px !important;
  margin-left: auto !important;
  border: 0 !important;
  color: var(--rk-text-muted) !important;
  transform: none !important;
}

.rk-select-arrow::before {
  content: "" !important;
  position: absolute !important;
  left: 50% !important;
  top: 50% !important;
  width: 7px !important;
  height: 7px !important;
  border-right: 2px solid currentColor !important;
  border-bottom: 2px solid currentColor !important;
  transform: translate(-50%, -64%) rotate(45deg) !important;
  transform-origin: center !important;
  transition:
    transform 240ms var(--rk-ease-glass),
    color 200ms var(--rk-ease-glass) !important;
}

.rk-select-menu.is-open .rk-select-arrow {
  color: var(--rk-yellow) !important;
  transform: none !important;
}

.rk-select-menu.is-open .rk-select-arrow::before {
  transform: translate(-50%, -36%) rotate(225deg) !important;
}

/* ==========================================================================
   4. 드롭다운 Portal: 모든 드롭다운 동일 애니메이션
   ========================================================================== */
.rk-select-menu .rk-select-list,
.rk-select-menu.is-open .rk-select-list {
  display: none !important;
  opacity: 0 !important;
  pointer-events: none !important;
}

.rk-select-portal {
  position: fixed !important;
  left: 0;
  top: 0;
  z-index: 1500 !important;
  display: block !important;
  visibility: hidden;
  min-width: 180px;
  max-height: min(280px, calc(100vh - 32px));
  overflow: auto;
  padding: 6px;
  border: 1px solid rgba(255,255,255,.14);
  border-radius: 16px;
  background:
    linear-gradient(180deg, rgba(255,255,255,.105), rgba(255,255,255,.036)),
    rgba(12,17,24,.985);
  box-shadow:
    0 24px 60px rgba(0,0,0,.44),
    inset 0 1px 0 rgba(255,255,255,.13);
  backdrop-filter: blur(28px) saturate(1.36);
  opacity: 0;
  pointer-events: none;
  transform: translateY(-10px) scale(.975);
  transform-origin: top center;
  transition:
    opacity 260ms var(--rk-ease-glass),
    transform 260ms var(--rk-ease-glass),
    visibility 0s linear 260ms;
}

.rk-select-portal.is-visible {
  visibility: visible;
  opacity: 1;
  pointer-events: auto;
  transform: translateY(0) scale(1);
  transition:
    opacity 260ms var(--rk-ease-glass),
    transform 260ms var(--rk-ease-glass),
    visibility 0s;
}

.rk-select-portal.is-above {
  transform-origin: bottom center;
}

.rk-select-portal.is-above:not(.is-visible) {
  transform: translateY(10px) scale(.975);
}

.rk-select-portal__option {
  display: flex;
  align-items: center;
  width: 100%;
  min-height: 34px;
  padding: 0 10px;
  border: 0;
  border-radius: 11px;
  background: transparent;
  color: var(--rk-text-soft);
  font-size: 12.5px;
  font-weight: 900;
  text-align: left;
  cursor: pointer;
  transition:
    background-color 160ms var(--rk-ease-glass),
    color 160ms var(--rk-ease-glass),
    transform 160ms var(--rk-ease-glass);
}

.rk-select-portal__option:hover {
  background: rgba(255,255,255,.075);
  color: var(--rk-text);
}

.rk-select-portal__option.is-selected {
  background:
    linear-gradient(135deg, rgba(247,209,0,.96), rgba(255,230,135,.96));
  color: #101010;
  box-shadow:
    0 9px 20px rgba(247,209,0,.16),
    inset 0 1px 0 rgba(255,255,255,.42);
}

/* 드롭다운/테이블/상세창 레이어 */
.rk-tabulator,
.rk-tabulator.tabulator {
  position: relative !important;
  z-index: 1 !important;
}

.rk-detail-backdrop {
  position: fixed !important;
  inset: 0 !important;
  z-index: 1900 !important;
}

.rk-detail-panel {
  position: fixed !important;
  right: 18px !important;
  top: 18px !important;
  bottom: 18px !important;
  z-index: 1910 !important;
  width: min(520px, calc(100vw - 36px)) !important;
}

.rk-modal-backdrop {
  position: fixed !important;
  z-index: 2000 !important;
}

.rk-toast {
  position: fixed !important;
  z-index: 3000 !important;
}

.rk-detail-backdrop.is-visible {
  display: block !important;
}

.rk-detail-panel.is-visible {
  opacity: 1 !important;
  pointer-events: auto !important;
  transform: translateX(0) scale(1) !important;
}

/* 드롭다운이 카드/테이블에 잘리지 않도록 */
.rk-content,
.rk-shell,
.rk-stack,
.rk-section,
.rk-card,
.rk-search-panel,
.rk-filter-drawer,
.rk-field,
.rk-select-wrap {
  overflow: visible !important;
}

.rk-section:has(.rk-search-panel),
.rk-search-panel,
.rk-filter-drawer,
.rk-filter-drawer.is-open {
  position: relative !important;
  z-index: 120 !important;
  overflow: visible !important;
}

.rk-section:has(.rk-tabulator) {
  position: relative !important;
  z-index: 2 !important;
}

/* ==========================================================================
   5. 모바일
   ========================================================================== */
@media (max-width: 760px) {
  .rk-footer__inner {
    grid-template-columns: 1fr !important;
    gap: 8px !important;
    padding: 10px 16px !important;
  }

  .rk-footer-meta {
    justify-self: start !important;
    flex-wrap: wrap;
  }

  .rk-footer-copy {
    white-space: normal !important;
  }

  .rk-detail-panel {
    left: 10px !important;
    right: 10px !important;
    top: 10px !important;
    bottom: 10px !important;
    width: auto !important;
  }

  .rk-select-portal {
    max-width: calc(100vw - 24px);
  }
}



/*
  BY JS 2026-06-05 V17 보완
  사용법:
  - landing.html 오픈 예정 랜딩 화면 전용 스타일이다.
  - body에는 .rk-landing-body를 부여한다.
  - main에는 .rk-landing-page와 data-rk-coming-date를 부여한다.
*/

/* ==========================================================================
   1. 오픈 예정 랜딩 기본 레이아웃
   ========================================================================== */
.rk-landing-body {
  min-height: 100vh;
  overflow-x: hidden;
  background:
    radial-gradient(circle at 72% 24%, rgba(247,209,0,.1), transparent 24%),
    radial-gradient(circle at 18% 78%, rgba(255,255,255,.05), transparent 26%),
    linear-gradient(135deg, #030509 0%, #101720 52%, #05070a 100%);
}

.rk-landing-page {
  position: relative;
  isolation: isolate;
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  padding: 28px;
  overflow: hidden;
}

.rk-landing-bg {
  position: fixed;
  inset: 0;
  z-index: -1;
  pointer-events: none;
}

.rk-landing-bg::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(255,255,255,.018) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.014) 1px, transparent 1px);
  background-size: 78px 78px;
  mask-image: radial-gradient(circle at center, black 0%, transparent 78%);
}

.rk-landing-orbit {
  position: absolute;
  border: 1px solid rgba(247,209,0,.12);
  border-radius: 999px;
  filter: drop-shadow(0 0 28px rgba(247,209,0,.08));
}

.rk-landing-orbit--a {
  right: -120px;
  top: 110px;
  width: 420px;
  height: 420px;
  animation: rkLandingOrbit 18s linear infinite;
}

.rk-landing-orbit--b {
  left: -160px;
  bottom: -120px;
  width: 520px;
  height: 520px;
  opacity: .58;
  animation: rkLandingOrbit 24s linear infinite reverse;
}

.rk-landing-sweep {
  position: absolute;
  right: -42%;
  top: 42%;
  width: 112%;
  height: 1px;
  background:
    linear-gradient(90deg, transparent, rgba(247,209,0,.62), rgba(255,255,255,.24), transparent);
  filter:
    drop-shadow(0 0 14px rgba(247,209,0,.42))
    drop-shadow(0 0 34px rgba(247,209,0,.16));
  transform: skewX(-14deg);
  opacity: 0;
  animation: rkLandingSweep 7.4s cubic-bezier(.16,1,.3,1) infinite;
}

/* ==========================================================================
   2. 상단 영역
   ========================================================================== */
.rk-landing-header {
  position: relative;
  z-index: 4;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  min-height: 48px;
}

.rk-landing-brand {
  display: inline-flex;
  align-items: center;
  gap: 12px;
}

.rk-landing-brand img {
  width: 34px;
  height: 34px;
  object-fit: contain;
  filter:
    brightness(0) invert(1)
    drop-shadow(0 0 16px rgba(247,209,0,.32));
}

.rk-landing-brand strong {
  display: block;
  color: var(--rk-text);
  font-size: 12px;
  line-height: 1;
  font-weight: 900;
  letter-spacing: .12em;
}

.rk-landing-brand em {
  display: block;
  margin-top: 6px;
  color: var(--rk-text-muted);
  font-size: 11px;
  line-height: 1;
  font-style: normal;
  font-weight: 800;
}

/* ==========================================================================
   3. 히어로
   ========================================================================== */
.rk-landing-hero {
  flex: 1 1 auto;
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(320px, 420px);
  align-items: center;
  gap: 42px;
  width: min(1180px, 100%);
  margin: 0 auto;
  padding: 70px 0 42px;
}

.rk-landing-copy {
  opacity: 0;
  transform: translateY(18px);
  animation: rkLandingIn 900ms cubic-bezier(.16,1,.3,1) 80ms forwards;
}

.rk-landing-kicker {
  margin: 0 0 18px;
  color: var(--rk-yellow);
  font-size: 13px;
  line-height: 1;
  font-weight: 900;
  letter-spacing: .24em;
}

.rk-landing-title {
  margin: 0;
  font-family: var(--rk-font-title);
  font-size: clamp(46px, 7vw, 86px);
  line-height: .96;
  letter-spacing: -.075em;
}

.rk-landing-title span {
  color: var(--rk-yellow);
  text-shadow:
    0 0 18px rgba(247,209,0,.24),
    0 0 52px rgba(247,209,0,.14);
}

.rk-landing-desc {
  max-width: 520px;
  margin: 22px 0 0;
  color: var(--rk-text-soft);
  font-size: 15px;
  line-height: 1.7;
}

.rk-landing-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 28px;
}

/* ==========================================================================
   4. 로고 스테이지 / 카운트다운
   ========================================================================== */
.rk-landing-stage {
  position: relative;
  min-height: 470px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  border: 1px solid rgba(255,255,255,.13);
  border-radius: 34px;
  background:
    linear-gradient(180deg, rgba(255,255,255,.074), rgba(255,255,255,.022)),
    rgba(10,15,22,.5);
  box-shadow:
    0 24px 64px rgba(0,0,0,.34),
    inset 0 1px 0 rgba(255,255,255,.1);
  backdrop-filter: blur(28px) saturate(1.34);
  overflow: visible;
  opacity: 0;
  transform: translateY(18px) scale(.985);
  animation: rkLandingIn 900ms cubic-bezier(.16,1,.3,1) 260ms forwards;
}

.rk-landing-stage::before,
.rk-landing-stage::after {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  pointer-events: none;
}

.rk-landing-stage::before {
  background:
    radial-gradient(86% 60% at 50% -12%, rgba(247,209,0,.08), transparent 58%),
    linear-gradient(180deg, rgba(255,255,255,.06), transparent 46%);
}

.rk-landing-stage::after {
  box-shadow: inset 0 0 0 1px rgba(247,209,0,.04);
}

.rk-landing-logo-wrap {
  position: relative;
  z-index: 1;
  margin-bottom: 30px;
}

.rk-landing-logo-loader {
  width: 190px !important;
  height: 190px !important;
}

.rk-countdown {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 8px;
  width: min(100%, 330px);
}

.rk-countdown__item {
  min-height: 78px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  border: 1px solid rgba(255,255,255,.095);
  border-radius: 18px;
  background:
    linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.024)),
    rgba(255,255,255,.03);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.08);
}

.rk-countdown__item strong {
  display: block;
  color: var(--rk-text);
  font-family: var(--rk-font-title);
  font-size: 28px;
  line-height: 1;
  letter-spacing: -.04em;
}

.rk-countdown__item span {
  margin-top: 8px;
  color: var(--rk-text-muted);
  font-size: 11px;
  font-weight: 900;
}

/* ==========================================================================
   5. 하단 카드
   ========================================================================== */
.rk-landing-panel {
  width: min(1180px, 100%);
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
  margin: 0 auto;
}

.rk-landing-card {
  position: relative;
  isolation: isolate;
  min-height: 118px;
  padding: 18px;
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 22px;
  background:
    linear-gradient(180deg, rgba(255,255,255,.066), rgba(255,255,255,.022)),
    rgba(10,15,22,.44);
  box-shadow:
    0 18px 42px rgba(0,0,0,.24),
    inset 0 1px 0 rgba(255,255,255,.09);
  backdrop-filter: blur(24px) saturate(1.28);
  opacity: 0;
  transform: translateY(14px);
  animation: rkLandingIn 780ms cubic-bezier(.16,1,.3,1) forwards;
}

.rk-landing-card:nth-child(1) { animation-delay: 420ms; }
.rk-landing-card:nth-child(2) { animation-delay: 520ms; }
.rk-landing-card:nth-child(3) { animation-delay: 620ms; }

.rk-landing-card::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  pointer-events: none;
  background:
    radial-gradient(80% 48% at 50% -12%, rgba(247,209,0,.055), transparent 62%);
}

.rk-landing-card__num {
  color: var(--rk-yellow);
  font-size: 11px;
  font-weight: 900;
  letter-spacing: .16em;
}

.rk-landing-card strong {
  display: block;
  margin-top: 12px;
  color: var(--rk-text);
  font-size: 15px;
  font-weight: 900;
}

.rk-landing-card p {
  margin: 7px 0 0;
  color: var(--rk-text-muted);
  font-size: 12px;
  line-height: 1.55;
}

/* ==========================================================================
   6. 랜딩 푸터
   ========================================================================== */
.rk-landing-footer {
  width: min(1180px, 100%);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin: 18px auto 0;
  padding: 12px 0 0;
  border-top: 1px solid rgba(255,255,255,.08);
  color: var(--rk-text-muted);
  font-size: 10.5px;
  font-weight: 900;
  letter-spacing: .06em;
}

/* ==========================================================================
   7. 애니메이션
   ========================================================================== */
@keyframes rkLandingIn {
  to {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}

@keyframes rkLandingSweep {
  0% {
    transform: translateX(0) skewX(-14deg) scaleX(.68);
    opacity: 0;
  }
  18% {
    opacity: .72;
  }
  64% {
    opacity: .32;
  }
  100% {
    transform: translateX(-128%) skewX(-14deg) scaleX(1);
    opacity: 0;
  }
}

@keyframes rkLandingOrbit {
  to {
    transform: rotate(360deg);
  }
}

/* ==========================================================================
   8. 반응형
   ========================================================================== */
@media (max-width: 920px) {
  .rk-landing-page {
    padding: 18px;
  }

  .rk-landing-hero {
    grid-template-columns: 1fr;
    gap: 26px;
    padding-top: 46px;
  }

  .rk-landing-stage {
    min-height: 390px;
  }

  .rk-landing-panel {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 560px) {
  .rk-landing-header {
    align-items: flex-start;
  }

  .rk-landing-title {
    font-size: 45px;
  }

  .rk-countdown {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .rk-landing-footer {
    align-items: flex-start;
    flex-direction: column;
  }
}
