@import url('https://fonts.googleapis.com/css2?family=Nanum+Brush+Script&display=swap');

/* Reset and General Styles */
* {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
}

:root {
    --ink: #2b3345;
    --deep-blue: #0f3460;
    --accent-blue: #3a77ff;
    --soft-blue: #d8e8ff;
}

body {
    font-family: 'Noto Sans KR', sans-serif;
    background-color: #f4f7fb;
    color: var(--ink);
}

/* Header */
header {
    background-color: #fff;
    padding: 10px 0;
    border-bottom: 1px solid #e4ebf5;
    position: relative;
}

.header-container {
    max-width: 1200px;
    margin: 0 auto;
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 0 20px;
}

.logo {
    display: flex;
    align-items: center;
    gap: 12px;
}

.logo-orb {
    width: 46px;
    height: 46px;
    border-radius: 50%;
    object-fit: cover;
    border: 2px solid var(--soft-blue);
    box-shadow: 0 8px 18px rgba(15, 52, 96, 0.28);
}

.logo h1 {
    font-family: 'Nanum Brush Script', 'Noto Serif KR', serif;
    font-size: 42px;
    line-height: 1;
    letter-spacing: 1px;
    color: #1e2433;
    font-weight: 400;
    text-shadow: 0 2px 4px rgba(15, 52, 96, 0.18);
    transform: translateY(1px);
    margin: 0;
}

nav ul {
    list-style: none;
    display: flex;
    align-items: center;
}

nav ul li {
    margin: 0 12px;
}

nav ul li a {
    text-decoration: none;
    color: #555;
    font-size: 20px;
    font-weight: 500;
    padding: 5px 0;
    position: relative;
    transition: color 0.3s ease;
}

nav ul li a:hover,
nav ul li a.active {
    color: var(--accent-blue);
}

nav ul li a.active::after {
    content: '';
    position: absolute;
    bottom: -5px;
    left: 0;
    width: 100%;
    height: 2px;
    background-color: var(--accent-blue);
}

.new-icon {
    display: inline-block;
    background-color: var(--accent-blue);
    color: #fff;
    font-size: 10px;
    font-weight: bold;
    border-radius: 50%;
    width: 16px;
    height: 16px;
    text-align: center;
    line-height: 16px;
    margin-left: 3px;
    vertical-align: text-top;
}

.header-icons {
    display: flex;
    align-items: center;
    gap: 10px;
}

.header-icon-btn {
    width: 42px;
    height: 42px;
    border: 1px solid #dbe4f2;
    border-radius: 999px;
    background-color: #fff;
    color: #3c4b65;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 18px;
    cursor: pointer;
    transition: border-color 0.2s ease, color 0.2s ease, background-color 0.2s ease;
}

.header-icon-btn:hover {
    border-color: #bed0eb;
    color: #244f8d;
    background-color: #f3f8ff;
}

.header-icon-btn:focus-visible {
    outline: 2px solid #4d84de;
    outline-offset: 2px;
}

.search-panel {
    position: fixed;
    inset: 0;
    z-index: 1400;
    padding: clamp(72px, 10vh, 106px) 24px 30px;
    background: linear-gradient(180deg, #ffffff 0%, #f8fbff 72%, #f3f9ff 100%);
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transition: opacity 0.28s ease, visibility 0.28s ease;
}

.search-panel::before,
.search-panel::after {
    content: '';
    position: absolute;
    border-radius: 50%;
    pointer-events: none;
}

.search-panel::before {
    width: 430px;
    height: 430px;
    top: -160px;
    left: -120px;
    background: radial-gradient(circle, rgba(149, 181, 235, 0.26) 0%, rgba(149, 181, 235, 0) 70%);
}

.search-panel::after {
    width: 520px;
    height: 520px;
    right: -190px;
    bottom: -240px;
    background: radial-gradient(circle, rgba(169, 205, 252, 0.3) 0%, rgba(169, 205, 252, 0) 72%);
}

header.search-open .search-panel {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
}

.search-shell {
    position: relative;
    z-index: 1;
    max-width: 980px;
    margin: 0 auto;
    padding: 28px 28px 30px;
    border-radius: 30px;
    border: 1px solid #d8e4f4;
    background: rgba(255, 255, 255, 0.85);
    box-shadow: 0 26px 60px rgba(32, 57, 93, 0.14);
}

.search-row {
    display: flex;
    align-items: center;
    gap: 18px;
}

.search-field-wrap {
    flex: 1;
    display: flex;
    align-items: center;
    border-bottom: 2px solid #c0d1e8;
    padding-bottom: 8px;
}

.search-input {
    flex: 1;
    border: none;
    background: transparent;
    color: #1d2f4a;
    font-size: clamp(31px, 3.2vw, 43px);
    font-weight: 500;
    padding: 0 10px 0 0;
    line-height: 1.3;
    letter-spacing: -0.4px;
    outline: none;
}

.search-input::placeholder {
    color: #a6b9d2;
}

.search-submit {
    width: 56px;
    height: 56px;
    border: none;
    border-radius: 999px;
    background: transparent;
    color: #5a759a;
    font-size: 30px;
    cursor: pointer;
    transition: color 0.2s ease, background-color 0.2s ease;
}

.search-submit:hover {
    color: #305885;
    background: rgba(219, 232, 251, 0.54);
}

.search-close {
    flex: 0 0 56px;
    width: 56px;
    height: 56px;
    border: none;
    border-radius: 999px;
    background: transparent;
    cursor: pointer;
    position: relative;
    transition: background-color 0.2s ease;
}

.search-close span {
    position: absolute;
    top: 50%;
    left: 50%;
    width: 30px;
    height: 2px;
    border-radius: 999px;
    background: #8da2bf;
}

.search-close span:first-child {
    transform: translate(-50%, -50%) rotate(45deg);
}

.search-close span:last-child {
    transform: translate(-50%, -50%) rotate(-45deg);
}

.search-close:hover {
    background: rgba(220, 233, 251, 0.54);
}

.search-tag-row {
    margin-top: 24px;
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 9px;
}

.search-tag {
    border: 1px solid #c9daef;
    background: linear-gradient(180deg, #eef5ff 0%, #e1ecfc 100%);
    color: #294a74;
    border-radius: 999px;
    padding: 9px 16px;
    font-size: clamp(16px, 1.35vw, 21px);
    font-weight: 600;
    cursor: pointer;
    transition: border-color 0.2s ease, background 0.2s ease, color 0.2s ease;
}

.search-tag:hover {
    border-color: #aac4e4;
    background: linear-gradient(180deg, #e4f0ff 0%, #d4e5fb 100%);
    color: #163c69;
}

.sr-only {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}

/* Hero Banner */
.hero-banner {
    position: relative;
    isolation: isolate;
    background:
        radial-gradient(circle at 50% 92%, rgba(164, 126, 216, 0.44) 0%, rgba(164, 126, 216, 0) 34%),
        radial-gradient(circle at 18% 16%, rgba(96, 132, 243, 0.28) 0%, rgba(96, 132, 243, 0) 30%),
        radial-gradient(circle at 86% 20%, rgba(94, 169, 244, 0.2) 0%, rgba(94, 169, 244, 0) 28%),
        linear-gradient(180deg, #0a1230 0%, #182c5e 54%, #2f3167 100%);
    padding: 60px 0;
    overflow: hidden;
}

.hero-banner::before {
    content: '';
    position: absolute;
    inset: 0;
    pointer-events: none;
    z-index: 0;
    background:
        radial-gradient(ellipse at 50% 16%, rgba(214, 230, 255, 0.16) 0%, rgba(214, 230, 255, 0) 44%),
        radial-gradient(ellipse at 24% 74%, rgba(190, 206, 255, 0.12) 0%, rgba(190, 206, 255, 0) 56%),
        radial-gradient(ellipse at 78% 78%, rgba(173, 194, 255, 0.1) 0%, rgba(173, 194, 255, 0) 52%);
}

.hero-banner::after {
    content: '';
    position: absolute;
    inset: 0;
    pointer-events: none;
    z-index: 0;
    background:
        radial-gradient(ellipse at 12% 102%, rgba(15, 22, 49, 0.9) 0%, rgba(15, 22, 49, 0) 42%),
        radial-gradient(ellipse at 34% 104%, rgba(18, 26, 56, 0.92) 0%, rgba(18, 26, 56, 0) 45%),
        radial-gradient(ellipse at 64% 103%, rgba(16, 23, 52, 0.9) 0%, rgba(16, 23, 52, 0) 44%),
        radial-gradient(ellipse at 88% 104%, rgba(13, 20, 46, 0.92) 0%, rgba(13, 20, 46, 0) 43%),
        linear-gradient(to bottom, rgba(3, 11, 23, 0.1), rgba(3, 11, 23, 0.24));
}

.night-nebula {
    position: absolute;
    inset: -24% -8% 16%;
    pointer-events: none;
    z-index: 1;
    opacity: 0.72;
    filter: blur(0.6px);
    background:
        conic-gradient(from 212deg at 52% 34%, rgba(185, 209, 255, 0.12) 0deg, rgba(185, 209, 255, 0) 44deg, rgba(226, 236, 255, 0.22) 92deg, rgba(226, 236, 255, 0) 144deg, rgba(193, 214, 255, 0.18) 186deg, rgba(193, 214, 255, 0) 232deg, rgba(226, 236, 255, 0.14) 288deg, rgba(226, 236, 255, 0) 360deg);
    animation: nebulaDrift 32s linear infinite;
}

.moon-crescent {
    position: absolute;
    top: 52px;
    left: 52%;
    width: 220px;
    height: 220px;
    border-radius: 50%;
    pointer-events: none;
    z-index: 2;
    animation: moonFloat 8s ease-in-out infinite;
}

.moon-crescent::before {
    content: '';
    position: absolute;
    inset: 0;
    border-radius: 50%;
    background:
        radial-gradient(circle at 34% 34%, rgba(255, 255, 255, 1) 0%, rgba(239, 246, 255, 0.96) 46%, rgba(176, 200, 246, 0.54) 70%, rgba(176, 200, 246, 0) 76%);
    box-shadow: 0 0 45px rgba(204, 224, 255, 0.7), 0 0 120px rgba(176, 206, 255, 0.34);
}

.moon-crescent::after {
    content: '';
    position: absolute;
    top: 14px;
    left: 78px;
    width: 176px;
    height: 176px;
    border-radius: 50%;
    background: radial-gradient(circle at 36% 40%, rgba(13, 22, 48, 0.98) 0%, rgba(17, 30, 64, 0.95) 82%);
}

.cloud-layer {
    position: absolute;
    left: -6%;
    width: 112%;
    height: 230px;
    pointer-events: none;
    z-index: 2;
    mix-blend-mode: screen;
}

.cloud-layer-back {
    top: 108px;
    opacity: 0.52;
    filter: blur(1px);
    background:
        radial-gradient(ellipse at 8% 58%, rgba(174, 191, 237, 0.34) 0%, rgba(174, 191, 237, 0) 52%),
        radial-gradient(ellipse at 38% 48%, rgba(163, 184, 235, 0.26) 0%, rgba(163, 184, 235, 0) 50%),
        radial-gradient(ellipse at 64% 56%, rgba(177, 196, 240, 0.3) 0%, rgba(177, 196, 240, 0) 54%),
        radial-gradient(ellipse at 92% 44%, rgba(171, 190, 235, 0.28) 0%, rgba(171, 190, 235, 0) 52%);
    animation: cloudDriftBack 36s linear infinite;
}

.cloud-layer-front {
    bottom: -8px;
    opacity: 0.38;
    filter: blur(2px);
    background:
        radial-gradient(ellipse at 12% 74%, rgba(191, 196, 236, 0.34) 0%, rgba(191, 196, 236, 0) 56%),
        radial-gradient(ellipse at 36% 72%, rgba(171, 178, 226, 0.31) 0%, rgba(171, 178, 226, 0) 58%),
        radial-gradient(ellipse at 62% 74%, rgba(179, 185, 231, 0.3) 0%, rgba(179, 185, 231, 0) 56%),
        radial-gradient(ellipse at 88% 70%, rgba(166, 173, 223, 0.32) 0%, rgba(166, 173, 223, 0) 57%);
    animation: cloudDriftFront 44s linear infinite reverse;
}

.star-layer {
    position: absolute;
    inset: -12%;
    pointer-events: none;
    z-index: 3;
    mix-blend-mode: screen;
}

.star-layer-1 {
    background:
        radial-gradient(circle at 7% 16%, rgba(255, 233, 157, 0.14) 0 0.8px, transparent 1.4px),
        radial-gradient(circle at 15% 72%, rgba(255, 226, 129, 0.92) 0 1.8px, transparent 2.7px),
        radial-gradient(circle at 23% 31%, rgba(255, 246, 206, 0.46) 0 1.1px, transparent 1.8px),
        radial-gradient(circle at 32% 57%, rgba(255, 214, 100, 0.16) 0 0.9px, transparent 1.5px),
        radial-gradient(circle at 41% 21%, rgba(255, 239, 182, 0.62) 0 1.3px, transparent 1.9px),
        radial-gradient(circle at 51% 76%, rgba(255, 222, 116, 0.24) 0 1px, transparent 1.6px),
        radial-gradient(circle at 63% 36%, rgba(255, 248, 214, 0.54) 0 1.2px, transparent 1.8px),
        radial-gradient(circle at 78% 64%, rgba(255, 207, 84, 0.94) 0 2.4px, transparent 3.4px),
        radial-gradient(circle at 84% 28%, rgba(255, 242, 180, 0.55) 0 1.4px, transparent 2.2px),
        radial-gradient(circle at 93% 45%, rgba(255, 224, 123, 0.34) 0 1px, transparent 1.6px);
    filter: drop-shadow(0 0 9px rgba(255, 219, 110, 0.48));
    animation: starsDriftOne 34s linear infinite, starsTwinkleOne 3.1s ease-in-out infinite alternate;
}

.star-layer-2 {
    background:
        radial-gradient(circle at 10% 39%, rgba(255, 253, 231, 0.98) 0 2.6px, transparent 4px),
        radial-gradient(circle at 27% 18%, rgba(255, 233, 145, 0.34) 0 1.1px, transparent 1.8px),
        radial-gradient(circle at 39% 83%, rgba(255, 210, 100, 0.2) 0 0.9px, transparent 1.6px),
        radial-gradient(circle at 49% 44%, rgba(255, 245, 194, 0.94) 0 2.1px, transparent 3.2px),
        radial-gradient(circle at 61% 12%, rgba(255, 225, 120, 0.39) 0 1.2px, transparent 2px),
        radial-gradient(circle at 74% 79%, rgba(255, 199, 78, 1) 0 3.2px, transparent 4.6px),
        radial-gradient(circle at 82% 52%, rgba(255, 248, 210, 0.72) 0 1.5px, transparent 2.4px),
        radial-gradient(circle at 95% 24%, rgba(255, 224, 122, 0.3) 0 1px, transparent 1.7px);
    filter: drop-shadow(0 0 16px rgba(255, 229, 133, 0.68));
    animation: starsDriftTwo 24s linear infinite, starsTwinkleTwo 2s ease-in-out infinite alternate;
}

.star-layer-3 {
    background:
        radial-gradient(circle at 6% 64%, rgba(255, 223, 134, 0.11) 0 0.7px, transparent 1.3px),
        radial-gradient(circle at 18% 14%, rgba(255, 244, 197, 0.28) 0 0.9px, transparent 1.5px),
        radial-gradient(circle at 29% 48%, rgba(255, 218, 104, 0.08) 0 0.6px, transparent 1.2px),
        radial-gradient(circle at 46% 24%, rgba(255, 242, 186, 0.2) 0 0.8px, transparent 1.3px),
        radial-gradient(circle at 57% 66%, rgba(255, 206, 82, 0.1) 0 0.7px, transparent 1.2px),
        radial-gradient(circle at 69% 39%, rgba(255, 247, 214, 0.24) 0 0.9px, transparent 1.4px),
        radial-gradient(circle at 81% 19%, rgba(255, 214, 100, 0.09) 0 0.7px, transparent 1.2px),
        radial-gradient(circle at 93% 73%, rgba(255, 233, 153, 0.19) 0 0.8px, transparent 1.4px);
    filter: blur(0.3px) drop-shadow(0 0 5px rgba(255, 223, 127, 0.22));
    animation: starsDriftThree 40s linear infinite, starsTwinkleThree 4.8s ease-in-out infinite alternate;
}

.star-layer-4 {
    background:
        radial-gradient(circle at 14% 22%, rgba(255, 252, 223, 1) 0 3.6px, transparent 5.2px),
        radial-gradient(circle at 30% 64%, rgba(255, 218, 99, 0.96) 0 2.8px, transparent 4px),
        radial-gradient(circle at 46% 30%, rgba(255, 247, 200, 1) 0 4.2px, transparent 6px),
        radial-gradient(circle at 62% 70%, rgba(255, 206, 76, 0.98) 0 3.1px, transparent 4.5px),
        radial-gradient(circle at 80% 26%, rgba(255, 250, 214, 1) 0 3.6px, transparent 5.4px),
        radial-gradient(circle at 90% 56%, rgba(255, 214, 92, 0.94) 0 2.6px, transparent 3.8px);
    filter: drop-shadow(0 0 18px rgba(255, 231, 142, 0.88));
    opacity: 0.86;
    animation: starsDriftFour 28s linear infinite, starsTwinkleFour 1.65s ease-in-out infinite alternate;
}

@keyframes nebulaDrift {
    0% { transform: translate3d(-12px, -8px, 0) rotate(-8deg); }
    50% { transform: translate3d(10px, 6px, 0) rotate(-6deg); }
    100% { transform: translate3d(-12px, -8px, 0) rotate(-8deg); }
}

@keyframes moonFloat {
    0% { transform: translate3d(-50%, 0, 0); }
    50% { transform: translate3d(-50%, -8px, 0); }
    100% { transform: translate3d(-50%, 0, 0); }
}

@keyframes cloudDriftBack {
    0% { transform: translateX(-1.5%); }
    50% { transform: translateX(1.4%); }
    100% { transform: translateX(-1.5%); }
}

@keyframes cloudDriftFront {
    0% { transform: translateX(2%); }
    50% { transform: translateX(-1.8%); }
    100% { transform: translateX(2%); }
}

@keyframes starsDriftOne {
    0% { transform: translate3d(0, 0, 0) scale(1) rotate(0deg); }
    18% { transform: translate3d(-26px, 14px, 0) scale(1.02) rotate(-0.6deg); }
    43% { transform: translate3d(31px, -12px, 0) scale(0.98) rotate(0.8deg); }
    74% { transform: translate3d(-14px, -18px, 0) scale(1.01) rotate(-0.5deg); }
    100% { transform: translate3d(0, 0, 0) scale(1) rotate(0deg); }
}

@keyframes starsDriftTwo {
    0% { transform: translate3d(0, 0, 0) scale(1) rotate(0deg); }
    24% { transform: translate3d(20px, 9px, 0) scale(1.04) rotate(0.5deg); }
    51% { transform: translate3d(-24px, -8px, 0) scale(0.96) rotate(-0.8deg); }
    77% { transform: translate3d(13px, -16px, 0) scale(1.05) rotate(0.4deg); }
    100% { transform: translate3d(0, 0, 0) scale(1) rotate(0deg); }
}

@keyframes starsDriftThree {
    0% { transform: translate3d(0, 0, 0) scale(1); }
    29% { transform: translate3d(-17px, 18px, 0) scale(1.03); }
    59% { transform: translate3d(19px, -13px, 0) scale(0.97); }
    100% { transform: translate3d(0, 0, 0) scale(1); }
}

@keyframes starsDriftFour {
    0% { transform: translate3d(0, 0, 0) scale(1); }
    32% { transform: translate3d(10px, -8px, 0) scale(1.06); }
    62% { transform: translate3d(-12px, 10px, 0) scale(0.94); }
    100% { transform: translate3d(0, 0, 0) scale(1); }
}

@keyframes starsTwinkleOne {
    0% { opacity: 0.2; }
    16% { opacity: 0.78; }
    44% { opacity: 0.34; }
    72% { opacity: 1; }
    100% { opacity: 0.56; }
}

@keyframes starsTwinkleTwo {
    0% { opacity: 0.14; }
    22% { opacity: 1; }
    46% { opacity: 0.26; }
    68% { opacity: 0.94; }
    100% { opacity: 0.44; }
}

@keyframes starsTwinkleThree {
    0% { opacity: 0.06; }
    35% { opacity: 0.36; }
    64% { opacity: 0.12; }
    100% { opacity: 0.22; }
}

@keyframes starsTwinkleFour {
    0% { opacity: 0.34; filter: drop-shadow(0 0 10px rgba(255, 229, 135, 0.44)); }
    18% { opacity: 1; filter: drop-shadow(0 0 32px rgba(255, 236, 167, 0.98)); }
    42% { opacity: 0.24; filter: drop-shadow(0 0 8px rgba(255, 221, 123, 0.3)); }
    68% { opacity: 0.96; filter: drop-shadow(0 0 28px rgba(255, 244, 190, 0.92)); }
    100% { opacity: 0.45; filter: drop-shadow(0 0 11px rgba(255, 224, 124, 0.38)); }
}

.banner-container {
    max-width: 1200px;
    margin: 0 auto;
    position: relative;
    padding: 0 20px;
    z-index: 4;
}

.banner-content {
    display: grid;
    grid-template-columns: minmax(0, 1.14fr) minmax(320px, 0.86fr);
    align-items: center;
    gap: clamp(22px, 4vw, 58px);
    position: relative;
    padding: 12px 0 18px;
}

.banner-content::before {
    content: '';
    position: absolute;
    inset: -4px 2% auto;
    height: 1px;
    background: linear-gradient(90deg, rgba(215, 229, 255, 0) 0%, rgba(215, 229, 255, 0.8) 48%, rgba(215, 229, 255, 0) 100%);
    pointer-events: none;
    z-index: 0;
}

.banner-text-box {
    background: linear-gradient(160deg, rgba(253, 255, 255, 0.97) 0%, rgba(236, 246, 255, 0.92) 100%);
    padding: clamp(20px, 2.4vw, 32px) clamp(28px, 3.4vw, 56px) clamp(14px, 1.9vw, 24px);
    border-radius: 30px;
    border: 1px solid rgba(196, 218, 255, 0.62);
    box-shadow: 0 24px 54px rgba(17, 36, 80, 0.33), inset 0 1px 0 rgba(255, 255, 255, 0.8);
    position: relative;
    max-width: 710px;
    z-index: 2;
    justify-self: start;
    transform: translateX(-16px);
    text-align: center;
    backdrop-filter: blur(5px);
}

.banner-text-box::after {
    content: '';
    position: absolute;
    inset: 20% -12% auto;
    height: 120px;
    z-index: -1;
    pointer-events: none;
    background: radial-gradient(ellipse at center, rgba(145, 183, 247, 0.32) 0%, rgba(145, 183, 247, 0) 72%);
}

.banner-badge {
    position: absolute;
    top: -18px;
    left: 28px;
    background: linear-gradient(120deg, #6ea8ff 0%, #4479d8 100%);
    color: #fff;
    padding: 10px 18px;
    border-radius: 999px;
    font-weight: 800;
    font-size: 20px;
    letter-spacing: 0.8px;
    min-width: 102px;
    box-shadow: 0 11px 24px rgba(47, 102, 196, 0.42);
}

.banner-subtitle {
    font-size: clamp(23px, 1.95vw, 31px);
    color: #506182;
    margin-bottom: 8px;
    font-weight: 600;
    display: inline-block;
    border-bottom: 2px dashed rgba(109, 130, 165, 0.45);
    padding-bottom: 4px;
}

.banner-title {
    font-size: clamp(33px, 3.6vw, 50px);
    font-weight: 900;
    color: #1a1f2a;
    line-height: 1.12;
    margin-top: 4px;
    letter-spacing: -1.25px;
    text-shadow: 0 1px 0 rgba(255, 255, 255, 0.62);
}

.banner-title-line {
    display: block;
}

.title-line-main {
    white-space: nowrap;
}

.title-line-sub {
    margin-top: 2px;
}

.banner-title .highlight {
    background: transparent;
    position: relative;
    z-index: 1;
}

.banner-title .highlight::after {
    content: '';
    position: absolute;
    bottom: 5px;
    left: 0;
    width: 100%;
    height: 15px;
    background-color: #fff176; /* Yellow highlighter */
    z-index: -1;
    transform: rotate(-1deg);
    border-radius: 5px;
    opacity: 0.8;
}

.banner-image-assets {
    min-height: clamp(400px, 44vw, 560px);
    display: flex;
    justify-content: flex-end;
    align-items: flex-end;
    position: relative;
    z-index: 2;
}

.image-aura {
    position: absolute;
    border-radius: 50%;
    pointer-events: none;
    mix-blend-mode: screen;
}

.aura-1 {
    width: clamp(260px, 24vw, 360px);
    height: clamp(260px, 24vw, 360px);
    top: 6%;
    right: 12%;
    background: radial-gradient(circle, rgba(164, 198, 255, 0.5) 0%, rgba(164, 198, 255, 0) 72%);
}

.aura-2 {
    width: clamp(180px, 15vw, 250px);
    height: clamp(180px, 15vw, 250px);
    bottom: 3%;
    right: -2%;
    background: radial-gradient(circle, rgba(209, 226, 255, 0.42) 0%, rgba(209, 226, 255, 0) 72%);
}

.banner-image-frame {
    width: min(100%, 470px);
    padding: 10px;
    border-radius: 40px;
    background: linear-gradient(158deg, rgba(250, 253, 255, 0.98) 0%, rgba(205, 223, 254, 0.86) 100%);
    border: 1px solid rgba(232, 240, 255, 0.84);
    box-shadow: 0 34px 52px rgba(6, 24, 62, 0.42), 0 0 60px rgba(179, 208, 255, 0.32);
    position: relative;
    transform: translateX(24px);
}

.banner-image-frame::before {
    content: '';
    position: absolute;
    inset: -10px;
    border-radius: 46px;
    border: 1px solid rgba(171, 201, 246, 0.33);
    pointer-events: none;
}

.couple-img {
    width: 100%;
    aspect-ratio: 4 / 5;
    object-fit: cover;
    object-position: 68% center;
    border-radius: 30px;
    border: 1px solid rgba(255, 255, 255, 0.9);
    box-shadow: inset 0 0 0 1px rgba(209, 225, 255, 0.22);
}

/* Responsive (simplified) */
@media (max-width: 768px) {
    .header-container { flex-direction: column; }
    .logo { margin-bottom: 10px; }
    .logo-orb { width: 38px; height: 38px; }
    .logo h1 { font-size: 34px; }
    .header-icons { gap: 8px; }
    .header-icon-btn { width: 38px; height: 38px; font-size: 16px; }
    .search-panel { padding: 82px 12px 20px; }
    .search-shell { border-radius: 18px; padding: 16px 14px 16px; }
    .search-row { gap: 8px; }
    .search-field-wrap { padding-bottom: 6px; }
    .search-input { font-size: 25px; }
    .search-submit { width: 44px; height: 44px; font-size: 22px; }
    .search-close { width: 44px; height: 44px; flex-basis: 44px; }
    .search-close span { width: 22px; }
    .search-tag-row { margin-top: 14px; justify-content: flex-start; gap: 7px; }
    .search-tag { font-size: 13px; padding: 7px 10px; }
    nav ul { margin-top: 10px; flex-wrap: wrap; justify-content: center; }
    .moon-crescent { width: 154px; height: 154px; top: 46px; left: 50%; }
    .moon-crescent::after { width: 122px; height: 122px; top: 11px; left: 52px; }
    .cloud-layer { height: 172px; }
    .cloud-layer-front { bottom: -18px; }
    .star-layer-4 { opacity: 0.68; }
    .hero-banner { padding: 50px 0 44px; }
    .banner-content { grid-template-columns: 1fr; gap: 20px; padding-top: 0; }
    .banner-text-box { max-width: 100%; padding: 30px 18px 24px; border-radius: 22px; transform: none; }
    .banner-text-box::after { inset: 22% -10% auto; height: 88px; }
    .banner-badge { top: -14px; left: 18px; font-size: 15px; padding: 8px 13px; min-width: 80px; }
    .banner-subtitle { font-size: 26px; margin-bottom: 10px; }
    .banner-title { font-size: clamp(40px, 10.4vw, 56px); letter-spacing: -0.9px; line-height: 1.2; }
    .title-line-main { white-space: normal; }
    .banner-image-assets { min-height: auto; justify-content: center; }
    .aura-1 { top: 2%; right: 20%; }
    .aura-2 { bottom: -4%; right: 10%; }
    .banner-image-frame { width: min(100%, 360px); border-radius: 28px; padding: 8px; transform: none; }
    .banner-image-frame::before { border-radius: 32px; inset: -8px; }
    .couple-img { aspect-ratio: 4 / 5; border-radius: 22px; object-position: 68% center; }
    .quick-menu-container { grid-template-columns: repeat(2, 1fr); gap: 10px; padding: 0 14px; }
    .quick-menu-item { min-height: 118px; padding: 14px 10px; border-radius: 16px; }
    .icon-circle { width: 48px; height: 48px; margin-bottom: 10px; font-size: 19px; }
    .quick-menu-item p { font-size: 13px; }
}

/* =========================================
   New Sections: Half Price, Zodiac, Popular
   ========================================= */

/* Common Section Styles */
.section-header {
    max-width: 1120px;
    margin: 0 auto 22px;
    padding: 0 24px;
}

.section-header h2 {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    font-size: clamp(27px, 2.35vw, 38px);
    font-weight: 800;
    color: #1e2f4a;
    letter-spacing: -0.7px;
}

.section-header h2::before {
    content: '';
    width: 20px;
    height: 20px;
    border-radius: 50%;
    background: radial-gradient(circle at 34% 34%, rgba(255, 255, 255, 1) 0%, rgba(221, 233, 255, 0.9) 42%, rgba(149, 181, 245, 0.54) 100%);
    box-shadow: 0 0 10px rgba(120, 157, 233, 0.65);
}

/* Zodiac Section */
.zodiac-section {
    padding: 66px 0 44px;
    background:
        radial-gradient(circle at 88% 2%, rgba(179, 208, 252, 0.22) 0%, rgba(179, 208, 252, 0) 42%),
        radial-gradient(circle at 8% 46%, rgba(212, 223, 252, 0.27) 0%, rgba(212, 223, 252, 0) 44%),
        linear-gradient(180deg, #f8fbff 0%, #f2f7ff 100%);
}

.zodiac-container {
    max-width: 1120px;
    margin: 0 auto;
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 16px;
    padding: 0 24px;
}

.zodiac-item {
    background: linear-gradient(162deg, rgba(17, 35, 74, 0.96) 0%, rgba(36, 64, 120, 0.91) 100%);
    text-align: left;
    padding: 20px 18px 18px;
    border-radius: 20px;
    border: 1px solid rgba(148, 176, 229, 0.36);
    box-shadow: 0 18px 34px rgba(9, 24, 59, 0.34);
    display: flex;
    flex-direction: column;
    min-height: 260px;
    transition: transform 0.22s ease, box-shadow 0.22s ease;
}

.zodiac-item:hover {
    transform: translateY(-5px);
    box-shadow: 0 24px 40px rgba(9, 24, 59, 0.42);
}

.zodiac-icon {
    width: 66px;
    height: 66px;
    margin: 0 0 14px;
    border-radius: 50%;
    overflow: hidden;
    background: linear-gradient(150deg, #eef5ff 0%, #d7e6ff 100%);
    box-shadow: 0 6px 14px rgba(8, 20, 54, 0.35);
    display: flex;
    justify-content: center;
    align-items: center;
}

.zodiac-icon img {
    width: 40px;
    height: 40px;
}

.zodiac-item h3 {
    font-size: 25px;
    font-weight: 700;
    margin-bottom: 10px;
    color: #f8fbff;
}

.zodiac-item p {
    font-size: 14px;
    color: #d7e6ff;
    line-height: 1.6;
    margin-bottom: 16px;
    flex: 1;
}

.more-link {
    align-self: flex-start;
    font-size: 12px;
    font-weight: 700;
    color: #c4d8ff;
    border: 1px solid rgba(174, 199, 246, 0.46);
    border-radius: 999px;
    text-decoration: none;
    padding: 7px 12px;
}

.more-link:hover {
    background: rgba(196, 216, 255, 0.1);
}

/* Half Price Section */
.half-price-section {
    padding: 46px 0 40px;
    background:
        radial-gradient(circle at 24% 12%, rgba(209, 223, 252, 0.3) 0%, rgba(209, 223, 252, 0) 42%),
        linear-gradient(180deg, #f2f7ff 0%, #f7f9ff 100%);
}

.half-price-container {
    max-width: 1120px;
    margin: 0 auto;
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 16px;
    padding: 0 24px;
}

.half-price-item {
    cursor: pointer;
    display: grid;
    grid-template-columns: minmax(170px, 42%) minmax(0, 1fr);
    border-radius: 22px;
    overflow: hidden;
    background: linear-gradient(154deg, #ffffff 0%, #ebf3ff 100%);
    border: 1px solid #d4e0f3;
    box-shadow: 0 16px 28px rgba(27, 45, 78, 0.16);
    transition: transform 0.22s ease, box-shadow 0.22s ease;
}

.half-price-item:hover {
    transform: translateY(-5px);
    box-shadow: 0 22px 36px rgba(27, 45, 78, 0.22);
}

.half-price-item .image-wrapper {
    position: relative;
    overflow: hidden;
    margin-bottom: 0;
}

.half-price-img {
    width: 100%;
    height: 100%;
    min-height: 196px;
    object-fit: cover;
    display: block;
    transition: transform 0.3s ease;
}

.half-price-item:hover .half-price-img {
    transform: scale(1.06);
}

.half-price-item .item-info {
    text-align: left;
    padding: 18px 18px 16px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: 10px;
}

.half-price-item h3 {
    font-size: 29px;
    font-weight: 700;
    margin-bottom: 0;
    color: #172843;
    letter-spacing: -0.4px;
    line-height: 1.24;
}

.price-box {
    font-size: 14px;
    color: #697990;
    display: flex;
    align-items: flex-end;
    gap: 10px;
}

.original-price {
    text-decoration: line-through;
    color: #9aa8bd;
    font-size: 16px;
}

.discount-price {
    color: #e53935;
    font-weight: 800;
    font-size: clamp(31px, 2.6vw, 42px);
    line-height: 1;
}

.discount-price .currency {
    font-size: 0.44em;
    font-weight: 600;
}

/* Quick Menu */
.quick-menu-section {
    padding: 40px 0 58px;
    background:
        radial-gradient(circle at 92% 10%, rgba(190, 214, 255, 0.3) 0%, rgba(190, 214, 255, 0) 38%),
        linear-gradient(180deg, #f7f9ff 0%, #f3f7ff 100%);
}

.quick-menu-container {
    max-width: 1120px;
    margin: 0 auto;
    display: grid;
    grid-template-columns: repeat(6, minmax(0, 1fr));
    gap: 12px;
    padding: 0 24px;
}

.quick-menu-item {
    text-align: center;
    cursor: pointer;
    min-height: 136px;
    background: linear-gradient(156deg, #ffffff 0%, #edf4ff 100%);
    border-radius: 18px;
    border: 1px solid #d5e2f6;
    box-shadow: 0 10px 20px rgba(27, 48, 88, 0.12);
    padding: 16px 10px 14px;
    transition: transform 0.22s ease, box-shadow 0.22s ease;
}

.quick-menu-item:hover {
    transform: translateY(-4px);
    box-shadow: 0 16px 26px rgba(27, 48, 88, 0.18);
}

.icon-circle {
    width: 56px;
    height: 56px;
    border-radius: 50%;
    margin: 0 auto 12px;
    display: flex;
    justify-content: center;
    align-items: center;
    font-size: 22px;
    border: 1px solid rgba(255, 255, 255, 0.55);
    box-shadow: 0 8px 16px rgba(46, 68, 112, 0.24);
}

.quick-menu-item p {
    font-size: 14px;
    color: #24344f;
    font-weight: 700;
    line-height: 1.4;
    letter-spacing: -0.2px;
}

/* Menu Item Colors */
.icon-circle.purple { background: linear-gradient(150deg, #ebddff 0%, #cdb0ff 100%); color: #6440ad; }
.icon-circle.orange { background: linear-gradient(150deg, #ffe7c2 0%, #ffd48c 100%); color: #bc6c00; }
.icon-circle.yellow { background: linear-gradient(150deg, #fff7cb 0%, #ffea85 100%); color: #a67800; }
.icon-circle.pink { background: linear-gradient(150deg, #ffd7e8 0%, #ffb8d8 100%); color: #b42873; }
.icon-circle.blue { background: linear-gradient(150deg, #d5eaff 0%, #afdcff 100%); color: #1e5ea7; }
.icon-circle.cyan { background: linear-gradient(150deg, #d5f7ff 0%, #aeeeff 100%); color: #0f7f96; }

/* Popular Horoscope Section */
.popular-section {
    padding: 42px 0 66px;
    background: linear-gradient(180deg, #f3f7ff 0%, #ffffff 100%);
}

.popular-container {
    max-width: 1120px;
    margin: 0 auto;
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 16px;
    padding: 0 24px;
}

.popular-item {
    cursor: pointer;
    background: #fff;
    border: 1px solid #dce6f5;
    border-radius: 16px;
    padding: 10px;
    box-shadow: 0 10px 18px rgba(25, 46, 86, 0.11);
    transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.popular-item:hover {
    transform: translateY(-4px);
    box-shadow: 0 14px 24px rgba(25, 46, 86, 0.17);
}

.popular-img-wrapper {
    width: 100%;
    height: 134px;
    overflow: hidden;
    border-radius: 12px;
    margin-bottom: 10px;
}

.popular-img-wrapper img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.3s ease;
}

.popular-item:hover .popular-img-wrapper img {
    transform: scale(1.05);
}

.popular-info p {
    font-size: 14px;
    color: #273754;
    line-height: 1.45;
    font-weight: 600;
}

.popular-info .rank {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 22px;
    height: 22px;
    border-radius: 50%;
    background: #edf4ff;
    color: #2c518a;
    font-weight: 800;
    margin-right: 6px;
}

/* Footer */
.site-footer {
    background-color: #efefef;
    border-top: 1px solid #e2e2e2;
    padding: 34px 0 70px;
}

.footer-container {
    max-width: 980px;
    margin: 0 auto;
    padding: 0 20px;
}

.footer-row {
    display: flex;
    flex-wrap: wrap;
    gap: 10px 14px;
    margin-bottom: 14px;
}

.footer-item {
    position: relative;
    font-size: 14px;
    color: #444b57;
    line-height: 1.6;
}

.footer-item::after {
    content: '|';
    margin-left: 14px;
    color: #b8bdc6;
}

.footer-row .footer-item:last-child::after {
    content: '';
    margin: 0;
}

.footer-links {
    margin-top: 28px;
    display: flex;
    gap: 22px;
}

.footer-links a {
    font-size: 14px;
    font-weight: 700;
    color: #1f2430;
    text-decoration: none;
}

.footer-copy {
    margin-top: 16px;
    font-size: 14px;
    color: #8f97a4;
}

/* Company Intro Modal */
body.modal-open {
    overflow: hidden;
}

.company-intro-modal {
    position: fixed;
    inset: 0;
    z-index: 1200;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 24px;
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transition: opacity 0.25s ease, visibility 0.25s ease;
}

.company-intro-modal.is-visible {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
}

.company-intro-backdrop {
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, rgba(11, 23, 44, 0.68) 0%, rgba(8, 19, 38, 0.58) 100%);
    backdrop-filter: blur(3px);
}

.company-intro-sheet {
    position: relative;
    width: min(860px, 100%);
    max-height: calc(100dvh - 48px);
    overflow: auto;
    border-radius: 24px;
    border: 1px solid #d8e1ee;
    background: linear-gradient(180deg, #ffffff 0%, #f8fbff 100%);
    box-shadow: 0 34px 76px rgba(3, 21, 42, 0.36);
    padding: 42px 42px 36px;
    transform: translateY(20px) scale(0.98);
    transition: transform 0.25s ease;
}

.company-intro-modal.is-visible .company-intro-sheet {
    transform: translateY(0) scale(1);
}

.company-intro-sheet::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 6px;
    border-radius: 24px 24px 0 0;
    background: linear-gradient(90deg, #1d3f73 0%, #2d6b9b 100%);
}

.company-intro-close {
    position: absolute;
    top: 18px;
    right: 18px;
    border: 1px solid #cfd9e8;
    background: #fbfdff;
    color: #1f3658;
    border-radius: 999px;
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 0.4px;
    padding: 8px 15px;
    cursor: pointer;
    transition: background-color 0.2s ease, color 0.2s ease, border-color 0.2s ease;
}

.company-intro-close:hover {
    background: #edf4ff;
    color: #16396f;
    border-color: #bacce7;
}

.company-intro-top {
    border-bottom: 1px solid #dfe6f2;
    padding-bottom: 20px;
}

.company-intro-kicker {
    font-size: 12px;
    font-weight: 800;
    letter-spacing: 1.4px;
    color: #3b5d89;
    margin-bottom: 8px;
}

.company-intro-heading {
    font-size: clamp(31px, 2.6vw, 42px);
    color: #15263f;
    margin-bottom: 10px;
    line-height: 1.3;
}

.company-intro-summary {
    font-size: clamp(15px, 1.35vw, 20px);
    color: #4a5f7f;
    line-height: 1.7;
    margin: 0;
}

.company-intro-body {
    margin-top: 24px;
    display: grid;
    gap: 14px;
}

.company-intro-paragraph {
    font-size: clamp(17px, 1.42vw, 23px);
    line-height: 1.9;
    color: #1f304b;
    margin: 0;
    padding: 4px 0 4px 16px;
    border-left: 3px solid #d7e2f3;
    word-break: keep-all;
}

.company-intro-pill-row {
    margin-top: 26px;
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    padding-top: 16px;
    border-top: 1px solid #dfe6f2;
}

.company-intro-pill {
    display: inline-flex;
    align-items: center;
    border-radius: 999px;
    border: 1px solid #cfe0f3;
    background-color: #edf5ff;
    color: #23456f;
    font-size: 13px;
    font-weight: 700;
    padding: 7px 12px;
}

/* Responsive for New Sections */
@media (max-width: 768px) {
    .section-header { padding: 0 14px; margin-bottom: 14px; }
    .section-header h2 { font-size: 23px; gap: 8px; }
    .section-header h2::before { width: 14px; height: 14px; }
    .zodiac-section { padding: 44px 0 28px; }
    .zodiac-container { grid-template-columns: 1fr; gap: 10px; padding: 0 14px; }
    .zodiac-item { min-height: auto; padding: 16px 14px 14px; border-radius: 16px; }
    .zodiac-icon { width: 58px; height: 58px; margin-bottom: 10px; }
    .zodiac-item h3 { font-size: 21px; margin-bottom: 7px; }
    .zodiac-item p { font-size: 13px; margin-bottom: 12px; }
    .more-link { padding: 6px 10px; }
    .half-price-section { padding: 30px 0 28px; }
    .half-price-container { grid-template-columns: 1fr; gap: 12px; padding: 0 14px; }
    .half-price-item { grid-template-columns: 1fr; border-radius: 16px; }
    .half-price-img { min-height: 150px; }
    .half-price-item .item-info { padding: 14px 14px 16px; gap: 8px; }
    .half-price-item h3 { font-size: 21px; line-height: 1.3; }
    .price-box { gap: 8px; }
    .original-price { font-size: 13px; }
    .discount-price { font-size: 29px; }
    .quick-menu-section { padding: 28px 0 36px; }
    .quick-menu-container { grid-template-columns: repeat(2, 1fr); gap: 10px; padding: 0 14px; }
    .quick-menu-item { min-height: 118px; padding: 14px 10px; border-radius: 16px; }
    .icon-circle { width: 48px; height: 48px; margin-bottom: 10px; font-size: 19px; }
    .quick-menu-item p { font-size: 13px; }
    .popular-section { padding: 30px 0 42px; }
    .popular-container { grid-template-columns: 1fr 1fr; gap: 10px; padding: 0 14px; }
    .popular-item { border-radius: 12px; padding: 8px; }
    .popular-img-wrapper { height: 104px; border-radius: 9px; }
    .popular-info p { font-size: 13px; }
    .site-footer { padding: 28px 0 42px; }
    .footer-row { margin-bottom: 10px; }
    .footer-item { font-size: 13px; }
    .footer-item::after { margin-left: 10px; }
    .footer-links { gap: 16px; margin-top: 20px; }
    .footer-links a { font-size: 13px; }
    .footer-copy { font-size: 13px; }
    .company-intro-modal { padding: 14px; }
    .company-intro-sheet { max-height: calc(100dvh - 28px); border-radius: 16px; padding: 22px 16px 20px; }
    .company-intro-sheet::before { border-radius: 16px 16px 0 0; }
    .company-intro-close { position: static; margin-left: auto; display: block; margin-bottom: 12px; }
    .company-intro-top { padding-bottom: 14px; }
    .company-intro-kicker { font-size: 11px; margin-bottom: 6px; }
    .company-intro-heading { font-size: 24px; margin-bottom: 6px; }
    .company-intro-summary { font-size: 14px; line-height: 1.6; }
    .company-intro-body { margin-top: 14px; gap: 12px; }
    .company-intro-paragraph { font-size: 15px; line-height: 1.8; padding-left: 10px; border-left-width: 2px; }
    .company-intro-pill-row { margin-top: 18px; padding-top: 12px; gap: 8px; }
    .company-intro-pill { font-size: 12px; padding: 6px 10px; }
}
