        @import url('https://fonts.googleapis.com/css2?family=Orbitron:wght@500;600;700;800;900&family=Outfit:wght@300;400;500;600;700;800&family=Space+Grotesk:wght@400;500;600;700&family=Space+Mono:wght@400;700&display=swap');

         * { margin: 0; padding: 0; box-sizing: border-box; -webkit-tap-highlight-color: rgba(255, 255, 255, 0);}

        body {
            font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Oxygen, Ubuntu, Cantarell, sans-serif;
            background: linear-gradient(135deg, #1a1a2e 0%, #16213e 100%);
            color: #e4e4e4;
            line-height: 1.6;
            padding: 20px;
            min-height: 100vh;
        }

        .container {
            max-width: 1200px;
            margin: 0 auto;
            background: rgba(26, 26, 46, 0.95);
            border-radius: 0;
            overflow: hidden;
            box-shadow: 0 20px 60px rgba(0, 0, 0, 0.5);
        }

        header {
            background: linear-gradient(135deg, #5aaee8 0%, #3e86bd 100%);
            padding: 14px;
            position: relative;
            overflow: hidden;
        }

        header::before {
            content: '';
            position: absolute;
            top: 0; left: 0; right: 0; bottom: 0;
            background: url('data:image/svg+xml,<svg width="100" height="100" xmlns="http://www.w3.org/2000/svg"><circle cx="50" cy="50" r="40" fill="rgba(255,255,255,0.03)"/></svg>');
            opacity: 0.5;
        }

        .header-main {
            position: relative;
            z-index: 1;
            display: grid;
            grid-template-columns: minmax(0, 1fr) auto;
            align-items: center;
            gap: 12px 18px;
            text-align: left;
        }

        .header-meta {
            display: flex;
            flex-direction: column;
            align-items: flex-end;
            gap: 8px;
            text-align: right;
        }

        h1 {
            font-size: 2.5em;
            font-weight: 800;
            text-transform: uppercase;
            letter-spacing: 2px;
            text-shadow: 2px 2px 4px rgba(0, 0, 0, 0.3);
            position: relative;
            z-index: 1;
        }

        .subtitle {
            font-size: 1.1em;
            margin-top: 0px;
            opacity: 1;
            position: relative;
            z-index: 1;
        }
        .credit {
            display: inline-block;
            font-size: 0.7em;
            margin-top: 0;
            font-weight: 500;
            top: 0;
            right: 0;
            background: rgba(23, 25, 44, 0.3);
            padding: 2px 13px;
            border-radius: 13px;
        }
        .feedback-btn {
            display: inline-block;
            margin-top: 0;
            font-size: 0.65em;
            font-weight: 500;
            color: #fff;
            background: rgba(23, 25, 44, 0.3);
            padding: 2px 13px;
            border-radius: 20px;
            cursor: pointer;
            transition: all 0.25s;
            letter-spacing: 0.3px;
        }
        .feedback-btn:hover { background: rgba(23, 25, 44, 0.3); color: #fff;}
        .discord-header-stripe {
            position: relative;
            z-index: 1;
            display: flex;
            align-items: center;
            justify-content: center;
            gap: 9px;
            margin: 12px -14px -14px;
            padding: 10px 14px;
            color: #fff;
            text-decoration: none;
            font-size: 0.86em;
            font-weight: 800;
            letter-spacing: 0.3px;
            background: linear-gradient(90deg, rgba(88, 101, 242, 0.92), rgba(114, 137, 218, 0.92));
            border-top: 1px solid rgba(255, 255, 255, 0.22);
            box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.12);
            transition: filter 0.2s, background 0.2s;
        }
        .discord-header-stripe:hover {
            color: #fff;
            filter: brightness(1.08);
            background: linear-gradient(90deg, rgba(88, 101, 242, 1), rgba(114, 137, 218, 1));
        }
        .discord-header-stripe svg {
            width: 20px;
            height: 20px;
            flex: 0 0 auto;
        }
        .discord-header-stripe span {
            line-height: 1.25;
        }
        .feedback-success { color: #4eafcd; font-size: 0.95em; text-align: center; padding: 18px 0; }
        .feedback-list-item { background: rgba(255,255,255,0.04); border: 1px solid rgba(255,255,255,0.08); border-radius: 0; padding: 14px 16px; margin-bottom: 10px; position: relative; }
        .feedback-list-item .fb-name { color: #5aaee8; font-weight: 600; font-size: 0.95em; }
        .feedback-list-item .fb-date { color: rgba(255,255,255,0.35); font-size: 0.75em; margin-left: 8px; }
        .feedback-list-item .fb-msg { color: rgba(255,255,255,0.75); font-size: 0.9em; margin-top: 6px; line-height: 1.5; white-space: pre-wrap; word-break: break-word; }
        .feedback-list-item .fb-delete { position: absolute; top: 10px; right: 12px; background: none; border: none; color: rgba(255,255,255,0.25); cursor: pointer; font-size: 1.1em; padding: 2px 6px; border-radius: 4px; transition: all 0.2s; }
        .feedback-list-item .fb-delete:hover { color: #5aaee8; background: rgba(90,174,232,0.15); }
        .feedback-empty { color: rgba(255,255,255,0.35); text-align: center; padding: 30px 0; font-style: italic; }

        /* ---- TOPBAR ---- */
        .topbar {
            position: fixed;
            top: 0; left: 0; right: 0;
            z-index: 1600;
            background: rgba(18, 18, 34, 0.86);
            backdrop-filter: blur(10px);
            border-bottom: 1px solid rgba(255,255,255,0.06);
        }
        .topbar-inner {
            max-width: 1200px;
            margin: 0 auto;
            padding: 10px 20px;
            display: flex;
            align-items: center;
            justify-content: space-between;
            gap: 12px;
        }
        .topbar-brand {
            display: flex; align-items: center; gap: 10px;
            font-weight: 800; letter-spacing: 1px; text-transform: uppercase; color: #fff; font-size: 0.95em;
        }
        .topbar-actions { display: flex; align-items: center; gap: 10px; }
        .user-pill {
            display: flex; align-items: center; gap: 10px;
            padding: 0; border-radius: 999px;
            background: rgba(255,255,255,0.06); border: 1px solid rgba(255,255,255,0.08);
            cursor: pointer; color: #fff; font-weight: 700; max-width: 240px;
        }
        .user-pill span { white-space: nowrap; overflow: hidden; text-overflow: ellipsis; max-width: 160px; font-size: 0.9em; opacity: 0.95; }
        .topbar .settings-dropdown { right: 0; top: calc(100% + 6px); z-index: 1700; }
        .topbar-spacer { height: 28px; }
        .btn-sm {
            padding: 6px 14px; border-radius: 0; border: 1px solid rgba(255,255,255,0.3);
            background: rgba(255,255,255,0.15); color: #fff; font-size: 0.8em; font-weight: 600; cursor: pointer; transition: all 0.2s;
        }
        .btn-sm:hover { background: rgba(255,255,255,0.25); }
        .settings-toggle { position: relative; z-index: 2; }
        .settings-dropdown {
            display: none; position: absolute; top: 100%; right: 0;
            background: rgba(26, 26, 46, 0.98); border: 1px solid rgba(90, 174, 232, 0.3);
            border-radius: 0; padding: 8px 0; min-width: 180px;
            box-shadow: 0 10px 30px rgba(0,0,0,0.4); margin-top: 6px;
        }
        .settings-dropdown.open { display: block; }
        .settings-dropdown button {
            display: block; width: 100%; text-align: left; padding: 10px 18px;
            background: none; border: none; color: #ccc; font-size: 0.9em; cursor: pointer; transition: background 0.2s;
        }
        .settings-dropdown button:hover { background: rgba(90, 174, 232, 0.15); color: #fff; }

        /* ---- AVATAR ---- */
        .avatar { width: 28px; height: 28px; border-radius: 999px; object-fit: cover; border: 1px solid rgba(90,174,232,0.35); }
        .avatar-fallback {
            display: flex; align-items: center; justify-content: center;
            background: rgba(90,174,232,0.18); color: #fff; font-weight: 800;
        }

        /* ---- TABS ---- */
        .tabs {
            display: flex;
            flex-wrap: wrap;
            background: rgba(22, 33, 62, 0.8);
            border-bottom: 3px solid #5aaee8;
            gap: 0;
        }

        .tab-button {
            flex: 1 1 auto;
            min-width: 150px;
            padding: 18px 20px;
            background: transparent;
            border: none;
            color: #c7c7c7;
            font-size: 1em;
            font-weight: 600;
            cursor: pointer;
            transition: all 0.3s ease;
            text-transform: uppercase;
            letter-spacing: 1px;
            position: relative;
            border-bottom: 3px solid transparent;
        }

        .tab-button::after {
            content: '';
            position: absolute;
            bottom: 0; left: 0; right: 0;
            height: 3px;
            background: #5aaee8;
            transform: scaleX(0);
            transition: transform 0.3s ease;
        }

        .tab-button:hover { background: rgba(90, 174, 232, 0.1); color: #5aaee8; }
        .tab-button.active { color: #fff; background: rgba(90, 174, 232, 0.15); }
        .tab-button.active::after { transform: scaleX(1); }

        .tabs .theme-tag.advanced {
            position: absolute;
            top: 0;
            right: 0;
            font-size: 0.5em;
            margin: 0;
            padding: 1px 5px;
        }

        /* ---- LANGUAGE SELECTOR ---- */
        .language-selector {
            display: block;
        }

        .language-selector select {
            background: rgba(22, 33, 62, 0.95);
            border: 1px solid rgba(90, 174, 232, 0.65);
            color: #fff;
            padding: 6px 28px 6px 10px;
            border-radius: 0;
            font-size: 0.78em;
            font-weight: 600;
            cursor: pointer;
            outline: none;
            transition: all 0.3s ease;
            appearance: none;
            max-width: 138px;
            background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23e94560' d='M6 9L1 4h10z'/%3E%3C/svg%3E");
            background-repeat: no-repeat;
            background-position: right 10px center;
        }

        .language-selector select:hover {
            border-color: #62c7ff;
            box-shadow: 0 0 10px rgba(90, 174, 232, 0.3);
        }

        .language-selector select option { background: #16213e; color: #fff; }

        .translate-loading {
            display: none;
            position: fixed;
            top: 50%; left: 50%;
            transform: translate(-50%, -50%);
            background: rgba(22, 33, 62, 0.98);
            border: 2px solid #5aaee8;
            border-radius: 0;
            padding: 30px 50px;
            z-index: 2000;
            text-align: center;
        }
        .translate-loading.active { display: block; }

        .spinner {
            border: 3px solid rgba(90, 174, 232, 0.3);
            border-top: 3px solid #5aaee8;
            border-radius: 50%;
            width: 40px; height: 40px;
            animation: spin 1s linear infinite;
            margin: 0 auto 15px;
        }

        @keyframes spin { 0% { transform: rotate(0deg); } 100% { transform: rotate(360deg); } }

        .tab-content {
            display: none;
            padding: 40px;
            animation: fadeIn 0.4s ease;
        }
        .tab-content.active { display: block; }

        @keyframes fadeIn {
            from { opacity: 0; transform: translateY(10px); }
            to { opacity: 1; transform: translateY(0); }
        }

        h2 {
            color: #5aaee8;
            font-size: 2em;
            margin-bottom: 20px;
            padding-bottom: 10px;
            border-bottom: 2px solid rgba(90, 174, 232, 0.3);
        }

        h3 {
            color: #ff6b6b;
            font-size: 1.5em;
            margin: 30px 0 15px;
            display: flex;
            align-items: center;
            gap: 10px;
        }
        h3::before { content: ''; color: #5aaee8; font-size: 0.8em; }

        /* ---- FLASH ---- */
        .flash { padding: 14px 20px; border-radius: 0; margin-bottom: 24px; font-weight: 600; animation: fadeIn 0.3s ease; }
        .flash.success { background: rgba(46, 204, 113, 0.15); border-left: 4px solid #2ecc71; color: #2ecc71; }
        .flash.danger  { background: rgba(231, 76, 60, 0.15); border-left: 4px solid #e74c3c; color: #e74c3c; }

        /* ---- ANNOUNCEMENT/RULE CARDS ---- */
        .card {
            background: rgba(22, 33, 62, 0.6); padding: 24px; border-radius: 0;
            border-left: 4px solid #5aaee8; margin-bottom: 20px; transition: all 0.3s ease;
        }
        .card:hover { transform: translateX(5px); background: rgba(22, 33, 62, 0.8); box-shadow: 0 5px 20px rgba(90, 174, 232, 0.2); }
        .card-header { display: flex; justify-content: space-between; align-items: flex-start; gap: 12px; margin-bottom: 12px; }
        .card-title { color: #fff; font-size: 1.25em; font-weight: 700; }
        .card-body { color: #d0d0d0; /*line-height: 1.8; white-space: pre-wrap;*/ }
        .card-body .accent { color: #5aaee8; font-weight: 700; }
        .card-footer { margin-top: 14px; display: flex; justify-content: space-between; align-items: flex-end; gap: 12px; }
        .footer-left { display: flex; gap: 10px; align-items: center; }
        .meta-right { text-align: right; display: flex; flex-direction: column; gap: 4px; }
        .meta-row { display: flex; align-items: center; justify-content: flex-end; gap: 10px; }
        .meta-date { font-size: 0.82em; color: #8b8b8b; gap: 8px; }
        .author { color: #5aaee8; font-weight: 600; font-size: 0.85em; }
        .date { color: #888; font-size: 0.85em; }
        .card-actions { display: flex; gap: 8px; flex-shrink: 0; }

        /* ---- Announcement images ---- */
        .ann-images-grid { margin-top: 12px; display: grid; grid-template-columns: repeat(auto-fill, minmax(140px, 1fr)); gap: 10px; }
        .ann-image-link { display: block; border-radius: 0; overflow: hidden; border: 1px solid rgba(255,255,255,0.08); background: rgba(0,0,0,0.15); cursor: pointer; padding: 0; }
        .ann-image { width: 100%; height: 120px; object-fit: cover; display: block; }
        .existing-images { display: flex; flex-wrap: wrap; gap: 10px; }
        .img-thumb { display: flex; align-items: center; gap: 8px; padding: 8px; border-radius: 0; border: 1px solid rgba(255,255,255,0.08); background: rgba(255,255,255,0.04); cursor: pointer; user-select: none; }
        .img-thumb input { width: 16px; height: 16px; accent-color: #5aaee8; }
        .img-thumb-pic { width: 64px; height: 48px; border-radius: 0; overflow: hidden; border: 1px solid rgba(255,255,255,0.08); background: rgba(0,0,0,0.15); display: block; }
        .img-thumb-pic img { width: 100%; height: 100%; object-fit: cover; display: block; }

        /* ---- BUTTONS ---- */
        .btn { padding: 10px 20px; border-radius: 0; border: none; font-size: 0.9em; font-weight: 600; cursor: pointer; transition: all 0.2s; display: inline-flex; align-items: center; gap: 6px; }
        .btn-primary { background: #5aaee8; color: #fff; }
        .btn-primary:hover { background: #3e86bd; box-shadow: 0 4px 15px rgba(90, 174, 232, 0.4); }
        .btn-edit { background: rgba(52, 152, 219, 0.2); color: #3498db; border: 1px solid rgba(52, 152, 219, 0.3); padding: 6px 12px; font-size: 0.8em; }
        .btn-edit:hover { background: rgba(52, 152, 219, 0.35); }
        .btn-delete { background: rgba(231, 76, 60, 0.2); color: #e74c3c; border: 1px solid rgba(231, 76, 60, 0.3); padding: 6px 12px; font-size: 0.8em; }
        .btn-delete:hover { background: rgba(231, 76, 60, 0.35); }
        .btn-cancel { background: rgba(255,255,255,0.1); color: #a0a0a0; }
        .btn-cancel:hover { background: rgba(255,255,255,0.15); }

        /* ---- FORMS ---- */
        .form-group { margin-bottom: 18px; }
        .form-group label { display: block; font-weight: 600; margin-bottom: 6px; color: #ccc; font-size: 0.9em; text-transform: uppercase; letter-spacing: 0.5px; }
        .form-control { width: 100%; padding: 12px 16px; background: rgba(22, 33, 62, 0.8); border: 2px solid rgba(90, 174, 232, 0.2); border-radius: 0; color: #e4e4e4; font-size: 1em; font-family: inherit; transition: border-color 0.3s; }
        .form-control:focus { outline: none; border-color: #5aaee8; box-shadow: 0 0 0 3px rgba(90, 174, 232, 0.15); }
        textarea.form-control { resize: vertical; min-height: 120px; }
        #addAnnContent, #editAnnContent { min-height: 240px; }

        /* ---- MODAL ---- */
        /* ---- SECTION RATING STRIP ---- */
        .section-rating-strip { display:flex; align-items:center; justify-content: center; gap:8px; flex-wrap:wrap; margin: -10px -40px 28px -40px; padding:10px 40px; background:rgba(90,174,232,0.06); border-bottom:1px solid rgba(90,174,232,0.12); font-size:1em; color:rgba(255,255,255,0.5); }
        .section-rating-strip .sr-label { margin-right:2px; white-space:nowrap; }
        .section-rating-strip .sr-btns { display:flex; gap:0; }
        .section-rating-strip .sr-btn { padding:4px 12px; border:1px solid rgba(255,255,255,0.1); background:rgba(255,255,255,0.04); color:rgba(255,255,255,0.55); cursor:pointer; font-size:0.95em; font-weight:600; transition:all 0.2s; white-space:nowrap; }
        .section-rating-strip .sr-btn:first-child { border-radius:6px 0 0 6px; }
        .section-rating-strip .sr-btn:last-child { border-radius:0 6px 6px 0; }
        .section-rating-strip .sr-btn:not(:first-child) { border-left:none; }
        .section-rating-strip .sr-btn:hover { background:rgba(90,174,232,0.15); color:#fff; border-color:rgba(90,174,232,0.3); }
        .section-rating-strip .sr-btn:hover + .sr-btn { border-left-color:rgba(90,174,232,0.3); }
        .section-rating-strip .sr-btn.voted { background:rgba(90,174,232,0.25); color:#fff; border-color:rgba(90,174,232,0.4); pointer-events:none; }
        .section-rating-strip .sr-btn.voted-dim { opacity:0.45; pointer-events:none; }
        .section-rating-strip .sr-thanks { color:rgba(78,175,205,0.85); font-weight:600; font-size:0.95em; animation:fadeIn 0.3s ease; }
        @media(max-width:600px){
            .section-rating-strip { margin:-8px -20px 20px -20px; padding:9px 20px; gap:6px; font-size:0.78em; }
            .section-rating-strip .sr-btn { padding:4px 9px; font-size:0.9em; }
        }
        /* ---- ADMIN RATINGS BLOCK ---- */
        .admin-ratings-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(260px,1fr)); gap:10px; }
        .admin-rating-card { background:rgba(255,255,255,0.03); border:1px solid rgba(255,255,255,0.07); border-radius:10px; padding:14px 16px; }
        .admin-rating-card .arc-name { font-weight:700; font-size:0.9em; color:#5aaee8; margin-bottom:8px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
        .admin-rating-card .arc-bars { display:flex; flex-direction:column; gap:4px; }
        .admin-rating-card .arc-row { display:flex; align-items:center; gap:8px; font-size:0.82em; }
        .admin-rating-card .arc-row .arc-label { width:56px; flex-shrink:0; color:rgba(255,255,255,0.5); }
        .admin-rating-card .arc-row .arc-bar { flex:1; height:16px; background:rgba(255,255,255,0.06); border-radius:4px; overflow:hidden; position:relative; }
        .admin-rating-card .arc-row .arc-fill { height:100%; border-radius:4px; transition:width 0.4s ease; }
        .admin-rating-card .arc-row .arc-fill.great { background:rgba(78,175,130,0.7); }
        .admin-rating-card .arc-row .arc-fill.average { background:rgba(233,180,69,0.7); }
        .admin-rating-card .arc-row .arc-fill.poor { background:rgba(90,174,232,0.5); }
        .admin-rating-card .arc-row .arc-count { width:28px; text-align:right; color:rgba(255,255,255,0.4); font-size:0.9em; flex-shrink:0; }
        .admin-rating-card .arc-total { font-size:0.75em; color:rgba(255,255,255,0.3); margin-top:6px; text-align:right; }

        /* ---- UNIVERSAL SEARCH ---- */
        .search-trigger { padding:6px 12px; border-radius:6px; border:1px solid rgba(255,255,255,0.15); background:rgba(255,255,255,0.06); color:rgba(255,255,255,0.5); font-size:0.78em; cursor:pointer; transition:all 0.2s; display:flex; align-items:center; gap:6px; }
        .search-trigger:hover { background:rgba(255,255,255,0.12); color:#fff; }
        .search-trigger kbd { font-size:0.85em; background:rgba(255,255,255,0.1); padding:1px 5px; border-radius:3px; font-family:inherit; }
        .search-overlay { display:none; position:fixed; top:0; left:0; right:0; bottom:0; background:rgba(0,0,0,0.75); backdrop-filter:blur(6px); z-index:2000; padding:10vh 20px 20px; justify-content:center; align-items:flex-start; }
        .search-overlay.open { display:flex; }
        .search-box { width:100%; max-width:640px; background:rgba(22,24,42,0.98); border:1px solid rgba(90,174,232,0.3); border-radius:16px; box-shadow:0 24px 80px rgba(0,0,0,0.6); overflow:hidden; max-height:80vh; display:flex; flex-direction:column; }
        .search-input-wrap { display:flex; align-items:center; gap:10px; padding:16px 20px; border-bottom:1px solid rgba(255,255,255,0.06); }
        .search-input-wrap svg { flex-shrink:0; opacity:0.4; }
        .search-input { flex:1; background:none; border:none; color:#fff; font-size:1.05em; outline:none; font-family:inherit; }
        .search-input::placeholder { color:rgba(255,255,255,0.3); }
        .search-input-wrap .search-clear { background:none; border:none; color:rgba(255,255,255,0.3); cursor:pointer; font-size:1.2em; padding:2px 6px; border-radius:4px; transition:all 0.15s; display:none; }
        .search-input-wrap .search-clear.vis { display:block; }
        .search-input-wrap .search-clear:hover { color:#5aaee8; background:rgba(90,174,232,0.15); }
        .search-filters { display:flex; gap:5px; padding:10px 20px; border-bottom:1px solid rgba(255,255,255,0.04); flex-wrap:wrap; }
        .sf-btn { padding:4px 10px; border-radius:5px; border:1px solid rgba(255,255,255,0.08); background:rgba(255,255,255,0.03); color:rgba(255,255,255,0.45); font-size:0.75em; font-weight:600; cursor:pointer; transition:all 0.15s; white-space:nowrap; }
        .sf-btn:hover { background:rgba(90,174,232,0.1); color:rgba(255,255,255,0.7); }
        .sf-btn.active { background:rgba(90,174,232,0.2); color:#fff; border-color:rgba(90,174,232,0.35); }
        .search-results { overflow-y:auto; padding:8px 0; flex:1; min-height:0; }
        .search-results::-webkit-scrollbar { width:5px; }
        .search-results::-webkit-scrollbar-thumb { background:rgba(255,255,255,0.1); border-radius:3px; }
        .sr-item { display:flex; flex-direction:column; padding:12px 20px; cursor:pointer; transition:background 0.12s; border-bottom:1px solid rgba(255,255,255,0.03); }
        .sr-item:hover, .sr-item.sr-active { background:rgba(90,174,232,0.1); }
        .sr-item-top { display:flex; align-items:center; gap:8px; }
        .sr-item-title { font-weight:700; font-size:0.9em; color:#fff; flex:1; min-width:0; }
        .sr-item-title mark { background:rgba(90,174,232,0.35); color:#fff; border-radius:2px; padding:0 1px; }
        .sr-item-section { font-size:0.68em; padding:2px 7px; border-radius:4px; background:rgba(90,174,232,0.12); color:#5aaee8; font-weight:600; flex-shrink:0; white-space:nowrap; }
        .sr-item-type { font-size:0.65em; padding:2px 6px; border-radius:4px; background:rgba(255,255,255,0.06); color:rgba(255,255,255,0.35); font-weight:600; flex-shrink:0; }
        .sr-item-snippet { font-size:0.82em; color:rgba(255,255,255,0.4); margin-top:4px; line-height:1.45; }
        .sr-item-snippet mark { background:rgba(90,174,232,0.25); color:rgba(255,255,255,0.7); border-radius:2px; padding:0 1px; }
        .search-empty { text-align:center; padding:40px 20px; color:rgba(255,255,255,0.25); font-style:italic; font-size:0.9em; }
        .search-footer { padding:8px 20px; border-top:1px solid rgba(255,255,255,0.04); display:flex; align-items:center; justify-content:space-between; }
        .search-footer-hint { font-size:0.7em; color:rgba(255,255,255,0.2); display:flex; align-items:center; gap:10px; }
        .search-footer-hint kbd { background:rgba(255,255,255,0.08); padding:1px 5px; border-radius:3px; font-family:inherit; }
        .search-count { font-size:0.72em; color:rgba(255,255,255,0.25); }
        @media(max-width:600px){
            .search-overlay { padding:4vh 10px 10px; }
            .search-box { max-height:88vh; border-radius:12px; }
            .search-input-wrap { padding:14px 16px; }
            .search-filters { padding:8px 16px; }
            .sr-item { padding:10px 16px; }
            .search-trigger kbd { display:none; }
        }

        .modal-overlay { display: none; position: fixed; top: 0; left: 0; right: 0; bottom: 0; background: rgba(0, 0, 0, 0.7); z-index: 1000; align-items: center; justify-content: center; padding: 20px; }
        .modal-overlay.active { display: flex; }
        .modal { background: rgba(26, 26, 46, 0.98); border-radius: 0; padding: 32px; max-width: 600px; width: 100%; max-height: 90vh; overflow-y: auto; border: 1px solid rgba(90, 174, 232, 0.3); box-shadow: 0 20px 60px rgba(0, 0, 0, 0.5); }
        .modal h3 { margin-top: 0; }
        .modal h3::before { content: none; }
        .modal-actions { display: flex; gap: 10px; justify-content: flex-end; margin-top: 24px; }
        .image-viewer { max-width: min(92vw, 980px); padding: 14px; position: relative; }
        .image-viewer img { width: 100%; height: auto; display: block; border-radius: 0; }
        .image-viewer-close { position: absolute; top: 10px; right: 12px; border: none; background: rgba(0,0,0,.55); color: #fff; font-size: 30px; line-height: 30px; width: 44px; height: 44px; border-radius: 999px; cursor: pointer; }
        .image-viewer-close:hover { background: rgba(0,0,0,.7); }

        /* ---- EDITOR STRIP ---- */
        .editor-strip { margin-top: 10px; padding: 10px; border-radius: 0; background: rgba(255,255,255,0.04); border: 1px solid rgba(255,255,255,0.06); display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
        .tool-btn, .emoji-btn { border: none; background: rgba(255,255,255,0.06); color: #fff; padding: 7px 10px; border-radius: 0; cursor: pointer; font-size: 0.95em; line-height: 1; }
        .tool-btn:hover, .emoji-btn:hover { background: rgba(255,255,255,0.10); }
        .tool-sep { width: 1px; height: 22px; background: rgba(255,255,255,0.12); margin: 0 6px; }
        .tool-accent { color: #5aaee8; font-weight: 800; }

        /* ---- EMOJI PICKER ---- */
        .emoji-picker { position: fixed; z-index: 1800; left: 50%; transform: translateX(-50%); bottom: 90px; width: min(520px, calc(100vw - 24px)); background: rgba(18, 18, 34, 0.95); backdrop-filter: blur(10px); border: 1px solid rgba(255,255,255,0.08); border-radius: 0; box-shadow: 0 20px 60px rgba(0,0,0,0.45); padding: 12px; display: none; }
        .emoji-picker.open { display: block; }
        .emoji-picker-top { display: flex; gap: 10px; align-items: center; margin-bottom: 10px; }
        .emoji-search { flex: 1; padding: 10px 12px; border-radius: 0; border: 1px solid rgba(255,255,255,0.10); background: rgba(255,255,255,0.06); color: #fff; outline: none; font-family: inherit; }
        .emoji-grid { display: grid; grid-template-columns: repeat(10, 1fr); gap: 6px; max-height: 260px; overflow: auto; padding-right: 2px; }
        .emoji-cell { border: none; background: rgba(255,255,255,0.06); border-radius: 0; padding: 8px 0; cursor: pointer; font-size: 18px; line-height: 1; }
        .emoji-cell:hover { background: rgba(255,255,255,0.12); }

        /* ---- ADMIN: USER CARDS ---- */
        .user-card {
            background: rgba(22, 33, 62, 0.6); padding: 24px; border-radius: 0;
            border-left: 4px solid #3498db; margin-bottom: 16px;
        }
        .user-card h4 { color: #3498db; font-size: 1.2em; margin-bottom: 12px; }
        .user-card h4::before { content: none; }
        .admin-create-grid { display:grid; grid-template-columns: 1fr 1fr 1fr; gap: 12px; margin-bottom: 16px; }
        .perm-grid {
            display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
            gap: 8px; margin: 12px 0;
        }
        .perm-item { display: flex; align-items: center; gap: 8px; font-size: 0.9em; color: #ccc; }
        .perm-item input[type="checkbox"] { accent-color: #5aaee8; width: 16px; height: 16px; }
        #tab-admin .admin-panel-tabs {
            display: flex;
            align-items: center;
            gap: 8px;
            flex-wrap: wrap;
            margin-bottom: 14px;
            padding: 8px;
            border: 1px solid rgba(90, 174, 232, 0.16);
            background: rgba(9, 14, 24, 0.36);
        }
        #tab-admin .admin-panel-tab {
            min-height: 38px;
            padding: 8px 12px;
            border: 1px solid rgba(90, 174, 232, 0.18);
            background: rgba(90, 174, 232, 0.08);
            color: rgba(223, 247, 255, 0.72);
            cursor: pointer;
            font-family: 'Orbitron', sans-serif;
            font-size: 0.78rem;
            font-weight: 800;
            text-transform: uppercase;
            flex: 1 1 180px;
        }
        #tab-admin .admin-panel-tab.active {
            background: rgba(90, 174, 232, 0.24);
            border-color: rgba(127, 226, 255, 0.48);
            color: #fff;
        }
        #tab-admin .admin-tab-panel {
            display: none;
            background: rgba(20, 28, 44, 0.46);
            border: 1px solid rgba(90, 174, 232, 0.14);
            padding: 18px;
        }
        #tab-admin .admin-tab-panel.active {
            display: block;
        }
        #tab-admin .admin-tab-panel > h2:first-child { margin-top: 0; }
        #tab-admin .admin-tab-panel > p:first-child,
        #tab-admin .admin-tab-panel > h2:first-child + p { margin-top: 0; }
        #tab-admin .admin-tab-panel .user-card:last-child,
        #tab-admin .admin-tab-panel > div:last-child { margin-bottom: 0; }
        @media (max-width: 760px) {
            .admin-create-grid { grid-template-columns: 1fr; }
            #tab-admin .admin-panel-tabs { gap: 6px; padding: 6px; }
            #tab-admin .admin-panel-tab { flex-basis: calc(50% - 6px); min-height: 36px; padding: 7px 8px; font-size: 0.68rem; }
            #tab-admin .admin-tab-panel { padding: 14px; }
        }

        /* ---- LIKE BUTTON ---- */
        .like-btn {
            display: inline-flex;
            align-items: center;
            gap: 6px;
            padding: 5px 12px;
            border-radius: 20px;
            border: 1px solid rgba(90, 174, 232, 0.25);
            background: rgba(90, 174, 232, 0.06);
            color: #a0a0a0;
            font-size: 0.85em;
            font-weight: 600;
            cursor: pointer;
            transition: all 0.2s ease;
            user-select: none;
        }
        .like-btn:hover {
            background: rgba(90, 174, 232, 0.15);
            border-color: rgba(90, 174, 232, 0.4);
            color: #5aaee8;
        }
        .like-btn.liked {
            background: rgba(90, 174, 232, 0.18);
            border-color: rgba(90, 174, 232, 0.5);
            color: #5aaee8;
        }
        .like-btn .like-icon {
            font-size: 1.1em;
            line-height: 1;
            transition: transform 0.2s ease;
        }
        .like-btn:active .like-icon {
            transform: scale(1.3);
        }
        .like-btn .like-count {
            min-width: 12px;
            text-align: center;
        }

        /* ---- EMPTY STATE ---- */
        .empty-state { text-align: center; padding: 60px 20px; color: #666; }
        .empty-state .icon { font-size: 3em; margin-bottom: 16px; }
        .empty-state p { font-size: 1.1em; margin-bottom: 20px; }

        /* ---- PINNED ROW ---- */
        .pinned-row {
            display: flex;
            gap: 16px;
            margin-bottom: 28px;
            align-items: stretch;
        }
        .pinned-row .duel-day-block {
            flex: 1;
            min-width: 0;
            margin-bottom: 0;
        }
        .pinned-row > #duelDayBlock {
            flex: 1;
            min-width: 0;
            display: flex;
        }
        .pinned-row > #duelDayBlock > .duel-day-block {
            flex: 1;
            margin-bottom: 0;
        }
        .pinned-side-stats {
            width: 200px;
            flex-shrink: 0;
            display: flex;
            flex-direction: column;
            gap: 16px;
        }
        .rose-count-block,
        .svs-current-block {
            width: 100%;
            flex-shrink: 0;
            border-radius: 0;
            overflow: hidden;
            border: 2px solid rgba(90, 174, 232, 0.85);
            background: linear-gradient(135deg, rgba(22, 33, 62, 0.85) 0%, rgba(26, 26, 46, 0.95) 100%);
            box-shadow: 0 4px 24px rgba(90, 174, 232, 0.08);
            display: flex;
            flex-direction: column;
            align-items: center;
            justify-content: center;
            text-align: center;
            padding: 18px 14px;
        }
        .rose-label,
        .svs-label {
            font-size: 0.78em;
            font-weight: 700;
            text-transform: uppercase;
            letter-spacing: 1.2px;
            color: #5aaee8;
            margin-bottom: 6px;
        }
        .rose-number,
        .svs-number {
            font-size: 2.8em;
            font-weight: 900;
            color: #fff;
            line-height: 1.1;
            margin-bottom: 4px;
        }
        .rose-buff,
        .svs-subtext {
            font-size: 0.78em;
            font-weight: 600;
            color: #f1c40f !important;
            letter-spacing: 0.5px;
        }
        .stat-editable {
            cursor: pointer;
            transition: transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease;
        }
        .stat-editable:hover {
            transform: translateY(-2px);
            box-shadow: 0 8px 28px rgba(90, 174, 232, 0.16);
            border-color: rgba(255, 128, 150, 0.95);
        }
        @media (max-width: 680px) {
            .pinned-row { flex-direction: column; }
            .pinned-side-stats { width: 100%; }
            .rose-count-block,
            .svs-current-block { width: 100%; flex-direction: row; gap: 14px; padding: 14px 20px; }
            .rose-label,
            .svs-label { margin-bottom: 0; }
            .rose-number,
            .svs-number { font-size: 2em; }
        }

        /* ---- CLOCK BLOCK ---- */
        .clock-block {
            margin-bottom: 16px; border-radius: 0; overflow: hidden;
            /*border: 2px solid rgba(90, 174, 232, 0.5);*/
            background: transparent !important;
            border: none !important;
        }
        .clock-row { display: flex; align-items: stretch; }
        .clock-cell {
            position: relative;
            flex: 1; padding: 10px 16px;
            border-right: 1px solid rgba(255,255,255,0.04);
            display: flex; align-items: center; justify-content: center; gap: 12px;
        }
        .clock-cell:last-child { border-right: none; }
        .clock-settings-toggle { display: none; }
        .clock-label { font-size: 0.6em; font-weight: 700; text-transform: uppercase; letter-spacing: 1px; color: #5aaee8; white-space: nowrap; }
        .clock-time { font-size: 1.3em; font-weight: 900; color: #fff; font-variant-numeric: tabular-nums; line-height: 1; }
        .clock-date { font-size: 0.68em; color: #777; font-weight: 600; }
        .clock-tz { font-size: 0.68em; color: #555; }
        .clock-select-row {
            padding: 6px 0px 8px; /*background: rgba(90,174,232,0.05);*/
            /*border-top: 1px solid rgba(255,255,255,0.04);*/
            display: flex; align-items: center; gap: 8px;
            justify-content: center;
        }
        .clock-select-row label { font-size: 0.55em; font-weight: 700; text-transform: uppercase; letter-spacing: 0.8px; color: #888; flex-shrink: 0; }
        .clock-tz-select {
            flex: 1; max-width: 250px; padding: 5px 8px; border-radius: 0;
            background: rgba(255,255,255,0.06); border: 1px solid rgba(90,174,232,0.2);
            color: #fff; font-size: 0.78em; font-family: inherit; cursor: pointer;
            appearance: none; -webkit-appearance: none;
            background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='10' viewBox='0 0 10 10'%3E%3Cpath fill='%23e94560' d='M5 7L1 3h8z'/%3E%3C/svg%3E");
            background-repeat: no-repeat; background-position: right 8px center; padding-right: 24px;
        }
        .clock-tz-select:focus { outline: none; border-color: #5aaee8; }
        .clock-tz-select option { background: #16213e; color: #fff; }
        .clock-offset-tag {
            font-size: 0.68em; font-weight: 700; color: #f1c40f;
            background: rgba(241,196,15,0.1); padding: 2px 8px; border-radius: 0;
            border: 1px solid rgba(241,196,15,0.15); white-space: nowrap;
        }

        @media (max-width: 768px) {
            .clock-tz-select {
                flex: 1; max-width: 160px; padding: 5px 8px; border-radius: 0;
            }
        }

        @media (max-width: 768px) {
            .clock-row { flex-direction: row; }
            .clock-cell { border-right: none; border-bottom: 1px solid rgba(255,255,255,0.04); padding: 5px 0px; }
            .clock-cell:last-child { border-bottom: none; }
            .clock-select-row { flex-wrap: wrap; }
        }

        /* ---- DUEL DAY PINNED BLOCK ---- */
        .duel-day-block {
            margin-bottom: 28px;
            border-radius: 0;
            overflow: hidden;
            border: 2px solid rgba(90, 174, 232, 0.85);
            background: linear-gradient(135deg, rgba(22, 33, 62, 0.85) 0%, rgba(26, 26, 46, 0.95) 100%);
            box-shadow: 0 4px 24px rgba(90, 174, 232, 0.08);
        }
        .duel-day-header {
            display: flex;
            align-items: center;
            gap: 12px;
            padding: 7px 20px;
            background: rgba(90, 174, 232, 0.22);
            border-bottom: 1px solid rgba(90, 174, 232, 0.15);
            font-size: 0.78em;
            font-weight: 700;
            text-transform: uppercase;
            letter-spacing: 1.5px;
            color: #5aaee8;
        }
        .duel-day-header .duel-pin {
            font-size: 1.1em;
        }
        .duel-day-body {
            display: flex;
            align-items: center;
            gap: 18px;
            padding: 18px 20px;
        }
        .duel-day-emoji {
            font-size: 2.4em;
            line-height: 1;
            flex-shrink: 0;
        }
        .duel-day-info { flex: 1; min-width: 0; }
        .duel-day-theme {
            font-size: 1.55em;
            font-weight: 800;
            color: #fff;
            margin-bottom: 4px;
        }
        .duel-day-theme .duel-tag {
            display: inline-block;
            background: rgba(90, 174, 232, 0.2);
            color: #ff6b6b;
            padding: 3px 12px;
            border-radius: 20px;
            font-size: 0.72em;
            font-weight: 700;
            margin-left: 10px;
            vertical-align: middle;
            border: 1px solid rgba(90, 174, 232, 0.3);
        }
        .duel-day-items {
            color: #b0b0b0;
            font-size: 0.92em;
            line-height: 1.5;
        }
        .duel-day-tip {
            margin-top: 6px;
            font-size: 0.85em;
            color: #888;
            font-style: italic;
        }
        .duel-day-details {
            margin-top: 10px;
            padding-top: 10px;
            border-top: 1px solid rgba(255,255,255,0.06);
        }
        .duel-detail-row {
            display: flex;
            gap: 8px;
            align-items: baseline;
            font-size: 0.85em;
            line-height: 1.5;
            margin-bottom: 4px;
            color: #b0b0b0;
        }
        .duel-detail-row .detail-icon { flex-shrink: 0; width: 18px; text-align: center; font-size: 0.9em; }
        .duel-detail-row strong { color: #5aaee8; }
        .duel-detail-row .detail-highlight { color: #2ecc71; font-weight: 600; }
        .duel-gh {
            margin-top: 8px;
            padding: 6px 12px;
            border-radius: 0;
            font-size: 0.82em;
            font-weight: 600;
            display: inline-flex;
            align-items: center;
            gap: 8px;
        }
        .duel-gh.gh-live {
            background: rgba(46, 204, 113, 0.12);
            border: 1px solid rgba(46, 204, 113, 0.35);
            color: #2ecc71;
        }
        .duel-gh .gh-dot {
            width: 8px; height: 8px; border-radius: 50%; background: #2ecc71; flex-shrink: 0;
            animation: gh-pulse 1.5s ease-in-out infinite;
        }
        @keyframes gh-pulse { 0%,100% { opacity:1; } 50% { opacity:0.4; } }
        .duel-gh.gh-off {
            background: rgba(255,255,255,0.04);
            border: 1px solid rgba(255,255,255,0.08);
            color: #888;
        }
        .duel-gh .gh-time { font-weight: 400; color: #aaa; margin-left: 2px; }
        @media (max-width: 520px) {
            .duel-day-body { flex-direction: column; align-items: flex-start; gap: 10px; }
            .duel-day-emoji { font-size: 2em; }
        }

        /* ---- LOADING SKELETON ---- */
        .loading-skeleton { animation: skeleton-pulse 1.5s ease-in-out infinite; background: rgba(255,255,255,0.06); border-radius: 0; height: 120px; margin-bottom: 20px; }
        @keyframes skeleton-pulse { 0%, 100% { opacity: 0.4; } 50% { opacity: 0.8; } }

        /* ---- GUIDE CONTENT STYLES ---- */
        .schedule-grid {
            display: grid; grid-template-columns: repeat(auto-fit, minmax(250px, 1fr)); gap: 20px; margin: 25px 0;
        }
        .schedule-card {
            background: rgba(22, 33, 62, 0.6); padding: 20px; border-radius: 0;
            border-left: 4px solid #5aaee8; transition: all 0.3s ease;
        }
        .schedule-card:hover { transform: translateX(5px); background: rgba(22, 33, 62, 0.8); box-shadow: 0 5px 20px rgba(90, 174, 232, 0.2); }
        .schedule-card h4 { color: #5aaee8; font-size: 1.2em; margin-bottom: 10px; text-transform: uppercase; letter-spacing: 1px; }
        .theme-tag {
            display: inline-block; background: rgba(90, 174, 232, 0.2); color: #ff6b6b;
            padding: 6px 14px; border-radius: 20px; font-size: 0.9em; font-weight: 600;
            margin: 5px 5px 5px 0; border: 1px solid rgba(90, 174, 232, 0.3);
        }
        .info-box { background: rgba(52, 152, 219, 0.15); padding: 20px; margin: 20px 0; border-radius: 0; }
        .info-box.warning { background: rgba(241, 196, 15, 0.15); border: 2px solid rgba(241, 196, 15, 0.4); }
        .info-box.success { background: rgba(46, 204, 113, 0.15); border: 2px solid rgba(46, 204, 113, 0.4); }
        .info-box.danger { background: rgba(231, 76, 60, 0.15); border: 2px solid rgba(231, 76, 60, 0.4); }
        .info-box strong { color: #3498db; display: block; margin-bottom: 8px; font-size: 1.1em; }
        .info-box.warning strong { color: #f1c40f; }
        .info-box.success strong { color: #2ecc71; }
        .info-box.danger strong { color: #e74c3c; }
        .points-table { width: 100%; margin: 25px 0; border-collapse: collapse; background: rgba(22, 33, 62, 0.4); border-radius: 0; overflow: hidden; }
        .points-table th { background: rgba(90, 174, 232, 0.3); color: #fff; padding: 15px; text-align: left; font-weight: 600; text-transform: uppercase; letter-spacing: 1px; }
        .points-table td { padding: 15px; border-bottom: 1px solid rgba(255, 255, 255, 0.05); }
        .points-table tr:hover { background: rgba(90, 174, 232, 0.1); }
        .tip {
            background: linear-gradient(135deg, rgba(90, 174, 232, 0.1) 0%, rgba(90, 174, 232, 0.05) 100%);
            border-radius: 0; padding: 20px; margin: 20px 0; border: 1px solid rgba(90, 174, 232, 0.2);
        }
        .tip::before { content: '\1F4A1    '; color: #f1c40f; font-weight: 700; font-size: 1.1em; }
        .tab-content ul, .tab-content ol { margin: 15px 0 15px 25px; }
        .tab-content li { margin: 10px 0; padding-left: 10px; }
        .tab-content li::marker { color: #5aaee8; }
        .info-box ul, .info-box ol { margin: 10px 0 0 20px; }
        .info-box li { margin: 5px 0; }

        /* ---- FACTION ICONS (guide) ---- */
        .faction-icon {
            width: 24px; height: 24px; object-fit: contain;
            vertical-align: middle; margin-right: 6px; display: inline-block;
            position: relative; top: -1px;
        }
        .faction-icon-sm {
            width: 18px; height: 18px; object-fit: contain;
            vertical-align: middle; margin-right: 4px; display: inline-block;
        }

        footer {
            background: rgba(22, 33, 62, 0.8); padding: 20px; text-align: center; color: #a0a0a0; font-size: 0.9em;
        }

        /* ---- Updates Button & Modal ---- */
        .updates-btn {
            position: fixed; top: 20px; right: 180px; z-index: 1000;
            background: #5aaee8; border: 2px solid #5aaee8; color: #fff;
            padding: 10px 16px; border-radius: 0; font-size: 0.9em; font-weight: 600;
            cursor: pointer; transition: all 0.3s ease; display: flex; align-items: center; gap: 6px;
        }
        .updates-btn:hover { border-color: #62c7ff; box-shadow: 0 0 10px rgba(90, 174, 232, 0.3); }
        .updates-btn .dot { width: 8px; height: 8px; background: #ffffff; border-radius: 50%; animation: pulse-dot 2s infinite; }
        @keyframes pulse-dot { 0%, 100% { opacity: 1; } 50% { opacity: 0.4; } }
        .updates-overlay { display: none; position: fixed; top: 0; left: 0; right: 0; bottom: 0; background: rgba(0, 0, 0, 0.6); z-index: 1500; align-items: center; justify-content: center; }
        .updates-overlay.active { display: flex; }
        .updates-modal { background: rgba(26, 26, 46, 0.98); border-radius: 0; max-width: 520px; width: 95%; max-height: 80vh; box-shadow: 0 20px 60px rgba(0, 0, 0, 0.5); border: 1px solid rgba(90, 174, 232, 0.3); overflow: hidden; }
        .updates-modal-header { display: flex; align-items: center; justify-content: space-between; padding: 20px 24px; border-bottom: 1px solid rgba(255, 255, 255, 0.06); }
        .updates-modal-header h3 { color: #5aaee8; font-size: 1.3em; margin: 0; }
        .updates-modal-header h3::before { content: none; }
        .updates-close { background: none; border: none; color: #a0a0a0; font-size: 1.4em; cursor: pointer; padding: 4px 8px; border-radius: 0; transition: all 0.2s; }
        .updates-close:hover { color: #fff; background: rgba(255, 255, 255, 0.1); }
        .updates-list { padding: 16px 24px; overflow-y: auto; max-height: calc(80vh - 70px); }
        .update-item { padding: 16px; margin-bottom: 12px; background: rgba(22, 33, 62, 0.6); border-left: 3px solid #5aaee8; border-radius: 0 10px 10px 0; transition: all 0.2s ease; }
        .update-item:last-child { margin-bottom: 0; }
        .update-item:hover { background: rgba(22, 33, 62, 0.9); transform: translateX(4px); }
        .update-date { font-size: 0.8em; color: #5aaee8; font-weight: 700; text-transform: uppercase; letter-spacing: 1px; margin-bottom: 6px; }
        .update-tag { display: inline-block; background: rgba(46, 204, 113, 0.2); color: #2ecc71; padding: 2px 10px; border-radius: 0; font-size: 0.75em; font-weight: 600; margin-left: 8px; vertical-align: middle; }
        .update-tag.improved { background: rgba(52, 152, 219, 0.2); color: #3498db; }
        .update-tag.fix { background: rgba(241, 196, 15, 0.2); color: #f1c40f; }
        .update-title { font-size: 1em; color: #fff; font-weight: 600; margin-bottom: 4px; }
        .update-desc { font-size: 0.88em; color: #a0a0a0; line-height: 1.5; }

        /* ---- RESPONSIVE ---- */
        @media (max-width: 768px) {
            body { padding: 0; }
            h1 { font-size: 1.8em; }
            .header-main { grid-template-columns: minmax(0, 1fr) minmax(118px, auto); gap: 10px; }
            .header-meta { gap: 6px; }
            .tab-content { padding: 20px; }
            .schedule-grid { grid-template-columns: 1fr; }
            .tabs { flex-wrap: wrap; }
            .tab-button { flex: 1 1 calc(50% - 0px); min-width: calc(50% - 0px); font-size: 0.85em; padding: 13px 10px; border-bottom: 2px solid rgba(90, 174, 232, 0.2); }
            .tab-button.active { border-bottom: 2px solid #5aaee8; }
            .language-selector select { font-size: 0.72em; padding: 5px 24px 5px 8px; max-width: 112px; }
            .topbar-inner { padding: 2px 8px; }
            .user-pill span { max-width: 110px; }
            .ann-image { height: 96px; }
            .emoji-grid { grid-template-columns: repeat(8, 1fr); }
            .card-header { flex-direction: column; }
            .card-actions { margin-top: 8px; }
            .updates-btn { top: auto; bottom: 20px; right: 20px; padding: 10px 14px; font-size: 0.85em; border-radius: 25px; box-shadow: 0 4px 15px rgba(0, 0, 0, 0.4); }
            .updates-modal { width: 95%; max-height: 85vh; }
        }
        @media (max-width: 480px) {
            .tab-button { flex: 1 1 100%; min-width: 100%; font-size: 0.9em; padding: 13px; text-align: center; }
            .language-selector select { width: auto; max-width: 112px; }
            .updates-btn { bottom: 15px; right: 15px; }
        }
    
        /* ---- ADVANCED GUIDE BLOCKS ---- */
        .advanced-block {
            margin: 18px 0;
            border: 1px solid rgba(241, 196, 15, 0.22);
            border-radius: 0;
            overflow: hidden;
            background: rgba(241, 196, 15, 0.06);
        }
        .advanced-block summary {
            list-style: none;
            cursor: pointer;
            padding: 14px 18px;
            font-weight: 700;
            color: #f1c40f;
            display: flex;
            align-items: center;
            justify-content: space-between;
            gap: 12px;
            user-select: none;
        }
        .advanced-block summary::-webkit-details-marker { display: none; }
        .advanced-block summary::after {
            content: '▾';
            color: #f1c40f;
            font-size: 1.15em;
            transition: transform 0.2s ease;
        }
        .advanced-block[open] summary::after { transform: rotate(180deg); }
        .advanced-block .advanced-content {
            padding: 0 18px 18px;
            color: #d9d9d9;
            border-top: 1px solid rgba(255,255,255,0.06);
            background: rgba(0,0,0,0.08);
        }
        .theme-tag.advanced {
            background: rgba(241,196,15,0.18);
            color: #f1c40f;
            border-color: rgba(241,196,15,0.28);
        }
        .scenario-grid {
            display: grid;
            grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
            gap: 16px;
            margin: 20px 0;
        }
        .scenario-card {
            background: rgba(241, 196, 15, 0.15);
            border-radius: 0;
            padding: 18px;
        }
        .scenario-card h4 {
            margin: 0 0 10px;
            color: #fff;
            font-size: 1.05em;
        }
        .scenario-card .label {
            display: inline-block;
            font-size: 0.75em;
            font-weight: 700;
            text-transform: uppercase;
            letter-spacing: 0.8px;
            margin-bottom: 10px;
            color: #f1c40f;
        }
        .mini-divider {
            height: 1px;
            background: rgba(255,255,255,0.08);
            margin: 14px 0;
        }

    

        /* ---- RESTYLE OVERRIDE ---- */
        :root {
            --bg-0: #0b0e17;
            --bg-1: #101421;
            --bg-2: #151a2a;
            --bg-3: #1b2134;
            --surface-1: #101421;
            --surface-2: #151a2a;
            --surface-3: #1b2134;
            --surface-soft: rgba(255, 255, 255, 0.04);
            --border-soft: rgba(172, 184, 214, 0.1);
            --border-strong: rgba(90, 174, 232, 0.34);
            --text-strong: #f4f7ff;
            --text-main: #cdd6e8;
            --text-muted: #8c9bb8;
            --text-faint: #64718d;
            --accent: #5aaee8;
            --accent-2: #62c7ff;
            --accent-blue: #5ba8ff;
            --accent-green: #42d7a4;
            --accent-yellow: #e7c66b;
            --accent-red: #ec7f9d;
            --radius-sm: 0;
            --radius-md: 0;
            --radius-lg: 0;
            --shadow-soft: none;
            --shadow-panel: none;
        }

        html {
            font-size: 15px;
            -webkit-font-smoothing: antialiased;
            -moz-osx-font-smoothing: grayscale;
            text-rendering: optimizeLegibility;
        }

        body {
            font-family: 'Space Grotesk', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
            background: var(--bg-0);
            color: var(--text-main);
            line-height: 1.62;
            letter-spacing: 0;
            padding: 0;
        }

        .frost-corners {
            position: fixed;
            inset: 0;
            z-index: 900;
            pointer-events: none;
        }

        .frost-corner {
            --frost-origin: 100% 0%;
            --frost-vein-a: 32deg;
            --frost-vein-b: 141deg;
            position: absolute;
            top: 0;
            width: min(56vw, 640px);
            height: min(36vw, 390px);
            opacity: 0.62;
            background:
                url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180' viewBox='0 0 180 180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='3' stitchTiles='stitch'/%3E%3CfeColorMatrix type='matrix' values='0 0 0 0 0.72 0 0 0 0 0.91 0 0 0 0 1 0 0 0 .34 0'/%3E%3C/filter%3E%3Crect width='180' height='180' filter='url(%23n)'/%3E%3C/svg%3E"),
                linear-gradient(var(--frost-vein-a), transparent 0 34%, rgba(220, 247, 255, 0.13) 34.4% 34.9%, transparent 35.4%),
                linear-gradient(var(--frost-vein-b), transparent 0 43%, rgba(164, 224, 255, 0.1) 43.3% 43.9%, transparent 44.4%),
                radial-gradient(circle at 83% 82%, rgba(235, 252, 255, 0.62) 0 1px, transparent 2px),
                radial-gradient(circle at 72% 64%, rgba(169, 226, 255, 0.42) 0 1px, transparent 2px),
                radial-gradient(circle at 90% 48%, rgba(226, 248, 255, 0.4) 0 1px, transparent 2px),
                radial-gradient(circle at 58% 82%, rgba(98, 199, 255, 0.28) 0 1px, transparent 2px),
                repeating-linear-gradient(135deg, transparent 0 16px, rgba(224, 249, 255, 0.09) 16px 17px, transparent 17px 34px),
                radial-gradient(ellipse at var(--frost-origin), rgba(235, 252, 255, 0.42) 0, rgba(151, 221, 255, 0.2) 28%, rgba(90, 174, 232, 0.08) 54%, transparent 75%);
            background-blend-mode: screen, screen, screen, screen, screen, screen, screen, normal, normal;
            backdrop-filter: none;
            -webkit-backdrop-filter: none;
            filter: drop-shadow(0 0 16px rgba(98, 199, 255, 0.12));
            contain: paint;
            mask-image: radial-gradient(ellipse at var(--frost-origin), #000 0 10%, rgba(0, 0, 0, 0.72) 25%, rgba(0, 0, 0, 0.26) 50%, rgba(0, 0, 0, 0.055) 72%, transparent 100%);
            -webkit-mask-image: radial-gradient(ellipse at var(--frost-origin), #000 0 10%, rgba(0, 0, 0, 0.72) 25%, rgba(0, 0, 0, 0.26) 50%, rgba(0, 0, 0, 0.055) 72%, transparent 100%);
            mix-blend-mode: screen;
        }

        .frost-corner::before {
            content: "";
            position: absolute;
            inset: 0;
            background:
                linear-gradient(24deg, transparent 0 47%, rgba(235, 252, 255, 0.18) 47.3% 47.7%, transparent 48%),
                linear-gradient(112deg, transparent 0 54%, rgba(151, 221, 255, 0.14) 54.2% 54.6%, transparent 55%),
                radial-gradient(circle at 84% 12%, rgba(255, 255, 255, 0.18), transparent 20%);
            opacity: 0.75;
            mask-image: inherit;
            -webkit-mask-image: inherit;
        }

        .frost-corner::after {
            content: "*  +  *\A   *    +\A+     *";
            white-space: pre;
            position: absolute;
            right: 18px;
            top: 18px;
            color: rgba(218, 247, 255, 0.48);
            font-family: 'Space Mono', monospace;
            font-size: clamp(0.7rem, 1.2vw, 1rem);
            line-height: 1.8;
            letter-spacing: 0.85em;
            text-shadow: 0 0 12px rgba(98, 199, 255, 0.55);
            opacity: 0.58;
        }

        .frost-corner.top-right {
            --frost-origin: 100% 0%;
            --frost-vein-a: 32deg;
            --frost-vein-b: 141deg;
            right: 0;
            top: 0;
            width: min(58vw, 660px);
            height: min(35vw, 380px);
        }

        .frost-corner.top-left {
            --frost-origin: 0% 0%;
            --frost-vein-a: 58deg;
            --frost-vein-b: 122deg;
            left: 0;
            top: 0;
            width: min(42vw, 470px);
            height: min(31vw, 330px);
            opacity: 0.46;
            background:
                url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180' viewBox='0 0 180 180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.82' numOctaves='3' stitchTiles='stitch'/%3E%3CfeColorMatrix type='matrix' values='0 0 0 0 0.72 0 0 0 0 0.91 0 0 0 0 1 0 0 0 .28 0'/%3E%3C/filter%3E%3Crect width='180' height='180' filter='url(%23n)'/%3E%3C/svg%3E"),
                linear-gradient(58deg, transparent 0 38%, rgba(220, 247, 255, 0.1) 38.2% 38.7%, transparent 39%),
                radial-gradient(circle at 18% 24%, rgba(226, 248, 255, 0.5) 0 1px, transparent 2px),
                radial-gradient(circle at 34% 56%, rgba(169, 226, 255, 0.32) 0 1px, transparent 2px),
                radial-gradient(circle at 10% 72%, rgba(226, 248, 255, 0.26) 0 1px, transparent 2px),
                repeating-linear-gradient(28deg, transparent 0 22px, rgba(188, 232, 255, 0.06) 22px 23px, transparent 23px 44px),
                radial-gradient(circle at 0 0, rgba(198, 238, 255, 0.28) 0, rgba(98, 199, 255, 0.12) 38%, rgba(90, 174, 232, 0.04) 58%, transparent 74%);
        }

        .frost-corner.top-left::after {
            right: auto;
            left: 26px;
            top: 22px;
            letter-spacing: 0.65em;
            transform: rotate(-8deg);
            opacity: 0.42;
        }

        .frost-corner.bottom-right {
            --frost-origin: 100% 100%;
            --frost-vein-a: 118deg;
            --frost-vein-b: 28deg;
            right: 0;
            bottom: 0;
            top: auto;
            width: min(46vw, 520px);
            height: min(30vw, 320px);
            opacity: 0.36;
            background:
                url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180' viewBox='0 0 180 180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.76' numOctaves='3' stitchTiles='stitch'/%3E%3CfeColorMatrix type='matrix' values='0 0 0 0 0.72 0 0 0 0 0.91 0 0 0 0 1 0 0 0 .22 0'/%3E%3C/filter%3E%3Crect width='180' height='180' filter='url(%23n)'/%3E%3C/svg%3E"),
                linear-gradient(118deg, transparent 0 44%, rgba(220, 247, 255, 0.09) 44.2% 44.8%, transparent 45.2%),
                radial-gradient(circle at 84% 76%, rgba(226, 248, 255, 0.38) 0 1px, transparent 2px),
                radial-gradient(circle at 60% 52%, rgba(169, 226, 255, 0.28) 0 1px, transparent 2px),
                repeating-linear-gradient(118deg, transparent 0 20px, rgba(188, 232, 255, 0.055) 20px 21px, transparent 21px 42px),
                radial-gradient(circle at 100% 100%, rgba(198, 238, 255, 0.28) 0, rgba(98, 199, 255, 0.11) 36%, rgba(90, 174, 232, 0.04) 58%, transparent 76%);
        }

        .frost-corner.bottom-right::after {
            top: auto;
            bottom: 24px;
            right: 14px;
            letter-spacing: 0.55em;
            transform: rotate(11deg);
            opacity: 0.36;
        }

        .frost-corner.bottom-left {
            --frost-origin: 0% 100%;
            --frost-vein-a: 154deg;
            --frost-vein-b: 62deg;
            left: 0;
            bottom: 0;
            top: auto;
            width: min(52vw, 590px);
            height: min(28vw, 300px);
            opacity: 0.32;
            background:
                url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180' viewBox='0 0 180 180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.7' numOctaves='3' stitchTiles='stitch'/%3E%3CfeColorMatrix type='matrix' values='0 0 0 0 0.72 0 0 0 0 0.91 0 0 0 0 1 0 0 0 .2 0'/%3E%3C/filter%3E%3Crect width='180' height='180' filter='url(%23n)'/%3E%3C/svg%3E"),
                linear-gradient(154deg, transparent 0 49%, rgba(220, 247, 255, 0.08) 49.2% 49.7%, transparent 50.1%),
                radial-gradient(circle at 14% 82%, rgba(226, 248, 255, 0.32) 0 1px, transparent 2px),
                radial-gradient(circle at 42% 66%, rgba(169, 226, 255, 0.24) 0 1px, transparent 2px),
                radial-gradient(circle at 68% 88%, rgba(98, 199, 255, 0.18) 0 1px, transparent 2px),
                repeating-linear-gradient(154deg, transparent 0 24px, rgba(188, 232, 255, 0.045) 24px 25px, transparent 25px 48px),
                radial-gradient(circle at 0 100%, rgba(198, 238, 255, 0.24) 0, rgba(98, 199, 255, 0.09) 34%, rgba(90, 174, 232, 0.035) 58%, transparent 76%);
        }

        .frost-corner.bottom-left::after {
            top: auto;
            right: auto;
            left: 20px;
            bottom: 16px;
            letter-spacing: 0.45em;
            transform: rotate(-14deg);
            opacity: 0.3;
        }

        .container {
            max-width: 1200px;
            width: calc(100% - 36px);
            min-height: calc(100vh - 52px);
            margin: 0 auto;
            background: var(--bg-0);
            border-radius: 0;
            box-shadow: none;
            border: 1px solid var(--border-soft);
            overflow: hidden;
        }

        header {
            background: var(--bg-1);
            border-bottom: 1px solid var(--border-soft);
            padding: 24px 24px 0;
            position: relative;
            overflow: hidden;
        }

        header::before {
            content: "";
            position: absolute;
            inset: -28% -4%;
            z-index: 0;
            pointer-events: none;
            opacity: 0.55;
            background-image:
                radial-gradient(circle at 4% 18%, rgba(235, 252, 255, 0.62) 0 0.9px, transparent 1.7px),
                radial-gradient(circle at 11% 63%, rgba(152, 220, 255, 0.38) 0 2.6px, transparent 6px),
                radial-gradient(circle at 19% 37%, rgba(255, 255, 255, 0.48) 0 1.1px, transparent 2.4px),
                radial-gradient(circle at 27% 82%, rgba(98, 199, 255, 0.3) 0 0.8px, transparent 1.7px),
                radial-gradient(circle at 34% 14%, rgba(235, 252, 255, 0.48) 0 3px, transparent 7px),
                radial-gradient(circle at 43% 58%, rgba(210, 244, 255, 0.38) 0 1px, transparent 2px),
                radial-gradient(circle at 52% 29%, rgba(255, 255, 255, 0.36) 0 0.7px, transparent 1.5px),
                radial-gradient(circle at 61% 76%, rgba(152, 220, 255, 0.36) 0 2.8px, transparent 6.4px),
                radial-gradient(circle at 68% 21%, rgba(235, 252, 255, 0.58) 0 1.2px, transparent 2.7px),
                radial-gradient(circle at 74% 49%, rgba(98, 199, 255, 0.28) 0 0.8px, transparent 1.6px),
                radial-gradient(circle at 83% 84%, rgba(255, 255, 255, 0.48) 0 3.4px, transparent 7.6px),
                radial-gradient(circle at 91% 32%, rgba(210, 244, 255, 0.42) 0 1px, transparent 2.1px),
                radial-gradient(circle at 97% 69%, rgba(235, 252, 255, 0.36) 0 0.8px, transparent 1.8px),
                radial-gradient(circle at 14% 91%, rgba(235, 252, 255, 0.34) 0 0.8px, transparent 1.8px),
                radial-gradient(circle at 31% 49%, rgba(152, 220, 255, 0.3) 0 1.1px, transparent 2.5px),
                radial-gradient(circle at 47% 8%, rgba(255, 255, 255, 0.36) 0 1.6px, transparent 3.8px),
                radial-gradient(circle at 79% 9%, rgba(98, 199, 255, 0.24) 0 0.9px, transparent 2px),
                radial-gradient(circle at 88% 58%, rgba(235, 252, 255, 0.44) 0 1.3px, transparent 3.2px),
                radial-gradient(circle at 6% 48%, rgba(255, 255, 255, 0.3) 0 0.7px, transparent 1.6px),
                radial-gradient(circle at 22% 7%, rgba(152, 220, 255, 0.28) 0 1.2px, transparent 2.8px),
                radial-gradient(circle at 36% 93%, rgba(235, 252, 255, 0.4) 0 1.4px, transparent 3.4px),
                radial-gradient(circle at 55% 68%, rgba(98, 199, 255, 0.22) 0 0.8px, transparent 1.8px),
                radial-gradient(circle at 64% 5%, rgba(255, 255, 255, 0.34) 0 0.9px, transparent 2px),
                radial-gradient(circle at 71% 91%, rgba(210, 244, 255, 0.32) 0 1.1px, transparent 2.6px),
                radial-gradient(circle at 86% 39%, rgba(235, 252, 255, 0.36) 0 0.8px, transparent 1.8px),
                radial-gradient(circle at 98% 14%, rgba(152, 220, 255, 0.32) 0 2.7px, transparent 6.2px);
            background-size: 100% 100%;
            animation: headerSnowDrift 7s linear infinite;
            mix-blend-mode: screen;
        }

        header::after {
            content: "";
            position: absolute;
            inset: -34% -6%;
            z-index: 0;
            pointer-events: none;
            opacity: 0.38;
            background-image:
                radial-gradient(circle at 7% 44%, rgba(255, 255, 255, 0.46) 0 3px, transparent 7px),
                radial-gradient(circle at 16% 9%, rgba(152, 220, 255, 0.32) 0 0.8px, transparent 1.8px),
                radial-gradient(circle at 24% 71%, rgba(235, 252, 255, 0.48) 0 1px, transparent 2px),
                radial-gradient(circle at 39% 26%, rgba(98, 199, 255, 0.34) 0 3.8px, transparent 8.4px),
                radial-gradient(circle at 48% 88%, rgba(210, 244, 255, 0.34) 0 0.8px, transparent 1.8px),
                radial-gradient(circle at 57% 42%, rgba(255, 255, 255, 0.3) 0 1.2px, transparent 3px),
                radial-gradient(circle at 72% 12%, rgba(235, 252, 255, 0.42) 0 0.9px, transparent 1.8px),
                radial-gradient(circle at 79% 66%, rgba(152, 220, 255, 0.3) 0 1.5px, transparent 3.6px),
                radial-gradient(circle at 94% 54%, rgba(255, 255, 255, 0.34) 0 0.8px, transparent 1.7px),
                radial-gradient(circle at 2% 78%, rgba(235, 252, 255, 0.3) 0 0.8px, transparent 1.8px),
                radial-gradient(circle at 33% 52%, rgba(152, 220, 255, 0.26) 0 1.1px, transparent 2.7px),
                radial-gradient(circle at 66% 86%, rgba(255, 255, 255, 0.34) 0 3.2px, transparent 7.2px),
                radial-gradient(circle at 87% 24%, rgba(210, 244, 255, 0.28) 0 1px, transparent 2.3px),
                radial-gradient(circle at 13% 23%, rgba(235, 252, 255, 0.3) 0 1px, transparent 2.4px),
                radial-gradient(circle at 29% 87%, rgba(255, 255, 255, 0.22) 0 0.8px, transparent 1.8px),
                radial-gradient(circle at 45% 12%, rgba(152, 220, 255, 0.24) 0 1.4px, transparent 3.3px),
                radial-gradient(circle at 53% 72%, rgba(235, 252, 255, 0.28) 0 0.9px, transparent 2px),
                radial-gradient(circle at 75% 37%, rgba(98, 199, 255, 0.22) 0 1.2px, transparent 2.9px),
                radial-gradient(circle at 98% 88%, rgba(255, 255, 255, 0.32) 0 2.8px, transparent 6.4px);
            background-size: 100% 100%;
            animation: headerSnowDriftSoft 10s linear infinite;
            mix-blend-mode: screen;
        }

        .header-main {
            position: relative;
            z-index: 1;
            max-width: 1280px;
            margin: 0 auto;
            gap: 12px 22px;
        }

        .discord-header-stripe {
            position: relative;
            z-index: 1;
        }

        @keyframes headerSnowDrift {
            0% {
                opacity: 0;
                transform: translate3d(-1.5%, -34%, 0);
            }
            12% {
                opacity: 0.55;
            }
            88% {
                opacity: 0.55;
            }
            100% {
                opacity: 0;
                transform: translate3d(2.5%, 34%, 0);
            }
        }

        @keyframes headerSnowDriftSoft {
            0% {
                opacity: 0;
                transform: translate3d(2%, -36%, 0);
            }
            14% {
                opacity: 0.38;
            }
            86% {
                opacity: 0.38;
            }
            100% {
                opacity: 0;
                transform: translate3d(-2%, 34%, 0);
            }
        }

        @media (prefers-reduced-motion: reduce) {
            header::before,
            header::after {
                animation: none;
            }
        }

        h1 {
            font-size: clamp(2rem, 3.6vw, 2.8rem);
            line-height: 1.05;
            font-weight: 800;
            font-family: 'Outfit', sans-serif;
            letter-spacing: -0.02em;
            text-transform: none;
            text-shadow: none;
        }

        .subtitle {
            font-size: 0.92rem;
            color: var(--text-muted);
            margin-top: 7px;
            letter-spacing: 0.01em;
        }

        .credit,
        .feedback-btn,
        .btn-sm,
        .search-trigger,
        .like-btn,
        .theme-tag,
        .update-tag,
        .duel-day-theme .duel-tag {
            border-radius: var(--radius-sm);
        }

        .credit {
            font-family: 'Space Mono', monospace;
            font-size: 0.68rem;
            padding: 4px 12px;
            background: rgba(90,174,232,0.14);
            border: 1px solid rgba(90,174,232,0.32);
            color: #d5f1ff;
        }

        .feedback-btn {
            font-size: 0.7rem;
            background: var(--surface-soft);
            border: 1px solid var(--border-soft);
            padding: 4px 12px;
            white-space: nowrap;
        }

        .discord-header-stripe {
            margin: 20px -24px 0;
            padding: 10px 24px;
            font-size: 0.82rem;
            background: rgba(98, 199, 255, 0.18);
            border-top: 1px solid rgba(98, 199, 255, 0.38);
            color: #f4fbff;
            box-shadow: none;
        }

        .discord-header-stripe:hover {
            background: rgba(98, 199, 255, 0.24);
            filter: none;
        }

        .topbar {
            background: var(--bg-1);
            backdrop-filter: none;
            border-bottom: 1px solid var(--border-soft);
        }

        .topbar-inner {
            max-width: 1280px;
            padding: 10px 20px;
        }

        .topbar-brand {
            font-family: 'Orbitron', 'Outfit', sans-serif;
            font-size: 0.88rem;
            letter-spacing: 0.08em;
            color: var(--text-strong);
        }

        .topbar-spacer {
            height: 52px;
        }

        .btn-sm,
        .search-trigger {
            min-height: 34px;
            padding: 7px 12px;
            font-size: 0.76rem;
            font-weight: 700;
            background: var(--surface-soft);
            border: 1px solid var(--border-soft);
            color: var(--text-main);
            box-shadow: none;
        }

        .btn-sm:hover,
        .search-trigger:hover,
        .settings-dropdown button:hover,
        .tab-button:hover,
        .btn-edit:hover,
        .btn-delete:hover,
        .btn-cancel:hover,
        .tool-btn:hover,
        .emoji-btn:hover,
        .sf-btn:hover,
        .sr-item:hover,
        .search-input-wrap .search-clear:hover,
        .updates-close:hover {
            box-shadow: none;
            transform: none;
        }

        .user-pill {
            background: var(--surface-soft);
            border: 1px solid var(--border-soft);
        }

        .settings-dropdown,
        .search-box,
        .modal,
        .updates-modal,
        .emoji-picker {
            background: var(--surface-1);
            border: 1px solid var(--border-soft);
            box-shadow: var(--shadow-panel);
        }

        .tabs {
            flex-wrap: wrap;
            overflow-x: visible;
            padding: 0;
            background: var(--bg-1);
            border-bottom: 1px solid var(--border-strong);
        }

        .tab-button,
        .tab-button[style] {
            flex: 1 1 auto !important;
            min-width: 150px !important;
            width: auto !important;
            padding: 15px 16px;
            font-size: 0.8rem;
            letter-spacing: 0;
            font-weight: 700;
            color: var(--text-muted);
            border-bottom-width: 2px;
            text-transform: none;
            background: transparent !important;
        }

        .tab-button::after {
            height: 2px;
            background: var(--accent);
        }

        .tab-button.active,
        .tab-button.active[style] {
            background: rgba(90, 174, 232, 0.13) !important;
            color: var(--text-strong);
        }

        .language-selector select,
        .clock-tz-select,
        .form-control,
        .search-input,
        .emoji-search {
            font-family: inherit;
        }

        .language-selector select,
        .clock-tz-select,
        .form-control {
            background-color: rgba(255,255,255,0.045);
            border: 1px solid rgba(255,255,255,0.1);
            color: var(--text-main);
            border-radius: 0;
            box-shadow: none;
        }

        .language-selector select,
        .clock-tz-select {
            font-size: 0.78rem;
        }

        .form-control {
            padding: 11px 13px;
            font-size: 0.92rem;
            line-height: 1.45;
        }

        .form-control:focus,
        .clock-tz-select:focus,
        .language-selector select:focus,
        .emoji-search:focus {
            outline: none;
            border-color: rgba(90, 174, 232, 0.6);
            box-shadow: 0 0 0 2px rgba(90, 174, 232, 0.14);
        }

        .form-group label,
        .clock-label,
        .clock-select-row label,
        .rose-label,
        .svs-label,
        .duel-day-header,
        .update-date,
        .sf-btn,
        .sr-item-section,
        .sr-item-type {
            font-size: 0.68rem;
            letter-spacing: 0.08em;
        }

        h1,
        h2,
        h3,
        h4,
        .topbar-brand,
        .tab-button,
        .card-title,
        .cal-title,
        .update-title,
        .theme-tag,
        .update-tag,
        .clock-offset-tag,
        .form-group label,
        .clock-label,
        .clock-select-row label,
        .rose-label,
        .svs-label,
        .duel-day-header,
        .sf-btn,
        .sr-item-section,
        .sr-item-type,
        .cc-form-label,
        .cc-summary-title,
        .cc-best-title,
        .cc-label,
        .cc-slot-label,
        .cc-bi-label,
        .svsp-help-section,
        .svsp-panel h3,
        .svsp-tool,
        .svsp-filter {
            font-family: 'Orbitron', 'Outfit', sans-serif !important;
        }

        .tab-content {
            padding: 30px 32px 34px;
        }

        h2 {
            font-family: 'Outfit', sans-serif;
            color: var(--text-strong);
            font-size: clamp(2.15rem, 3vw, 3rem);
            font-weight: 800;
            line-height: 1.08;
            margin-bottom: 24px;
            padding-bottom: 14px;
            border-bottom: 1px solid var(--border-soft);
            letter-spacing: -0.01em;
        }

        h3 {
            font-family: 'Outfit', sans-serif;
            color: #a8dcff;
            font-size: clamp(1.45rem, 2.1vw, 2rem);
            font-weight: 750;
            line-height: 1.15;
            margin: 34px 0 16px;
            gap: 8px;
        }

        h4,
        .schedule-card h4,
        .scenario-card h4,
        .user-card h4 {
            font-size: 0.98rem;
            line-height: 1.25;
            letter-spacing: 0.01em;
            font-weight: 700;
        }

        p,
        .card-body,
        .duel-day-items,
        .duel-day-tip,
        .duel-detail-row,
        .update-desc,
        .tab-content li,
        .info-box,
        .tip,
        .empty-state p,
        .fb-msg,
        .feedback-success,
        .feedback-empty,
        .sr-item-snippet {
            font-size: 0.9rem;
            line-height: 1.55;
            color: var(--text-main);
        }

        .author,
        .date,
        .meta-date,
        .clock-date,
        .clock-tz,
        .search-count,
        .search-footer-hint,
        .fb-date,
        .update-desc,
        .empty-state,
        footer,
        .duel-gh .gh-time,
        .rose-buff,
        .svs-subtext {
            color: var(--text-muted);
        }

        .card,
        .schedule-card,
        .user-card,
        .scenario-card,
        .feedback-list-item,
        .update-item,
        .info-box,
        .tip,
        .advanced-block,
        .flash,
        .rose-count-block,
        .svs-current-block,
        .duel-day-block,
        .clock-block {
            background: var(--surface-2);
            border-radius: var(--radius-md);
            box-shadow: none;
        }

        .card,
        .schedule-card,
        .user-card,
        .scenario-card,
        .feedback-list-item,
        .update-item {
            border: 1px solid var(--border-soft);
            padding: 18px 20px;
        }

        .card:hover,
        .schedule-card:hover,
        .update-item:hover,
        .stat-editable:hover {
            transform: none;
            background: var(--surface-3);
            box-shadow: none;
        }

        .card-title {
            font-size: 1.08rem;
            line-height: 1.25;
            font-weight: 750;
        }

        .card-header {
            margin-bottom: 10px;
        }

        .ann-images-grid {
            gap: 8px;
        }

        .ann-image-link,
        .img-thumb,
        .img-thumb-pic,
        .image-viewer img {
            border-radius: 0;
        }

        .btn {
            min-height: 36px;
            padding: 8px 14px;
            border-radius: 0;
            font-size: 0.8rem;
            font-weight: 700;
            letter-spacing: 0.01em;
        }

        .btn-primary {
            background: var(--accent);
        }

        .btn-primary:hover {
            background: #d93e59;
        }

        .btn-edit,
        .btn-delete,
        .btn-cancel {
            padding: 6px 10px;
            font-size: 0.74rem;
            border-radius: 0;
        }

        .search-overlay,
        .modal-overlay,
        .updates-overlay {
            backdrop-filter: blur(4px);
        }

        .search-input-wrap,
        .search-filters,
        .search-footer,
        .updates-modal-header,
        .duel-day-header,
        .clock-select-row,
        .advanced-block .advanced-content {
            border-color: rgba(255,255,255,0.06);
        }

        .search-input {
            font-size: 0.98rem;
        }

        .sr-item-title {
            font-size: 0.84rem;
            font-weight: 700;
        }

        .sr-item-snippet {
            font-size: 0.8rem;
        }

        .tool-btn, .emoji-btn {
            background: rgba(255,255,255,0.055);
            border-radius: 0;
            font-size: 0.88rem;
        }

        .editor-strip {
            border-radius: 0;
            background: rgba(255,255,255,0.03);
        }

        .like-btn {
            padding: 4px 10px;
            font-size: 0.76rem;
            background: rgba(90,174,232,0.08);
        }

        .flash {
            padding: 12px 16px;
            border-radius: 0;
            font-size: 0.86rem;
        }

        .pinned-row {
            gap: 14px;
            margin-bottom: 22px;
        }

        .rose-count-block,
        .svs-current-block,
        .duel-day-block {
            border: 1px solid var(--border-strong);
            background: var(--surface-2);
        }

        .rose-number,
        .svs-number {
            font-size: 2.35rem;
            letter-spacing: -0.04em;
        }

        .clock-row {
            background: transparent;
        }

        .clock-cell {
            padding: 10px 14px;
            border-right-color: rgba(255,255,255,0.05);
            justify-content: center;
        }

        .clock-time {
            font-size: 1.4rem;
            font-weight: 800;
            letter-spacing: -0.01em;
        }

        .duel-day-header {
            padding: 8px 16px;
            background: rgba(90,174,232,0.12);
        }

        .duel-day-body {
            padding: 16px 18px;
            gap: 14px;
        }

        .duel-day-emoji {
            font-size: 2rem;
        }

        .duel-day-theme {
            font-size: 1.06rem;
            font-weight: 800;
        }

        .duel-gh,
        .theme-tag,
        .update-tag,
        .clock-offset-tag {
            font-size: 0.72rem;
            font-weight: 700;
        }

        .schedule-grid,
        .scenario-grid {
            gap: 16px;
            margin: 20px 0;
        }

        .theme-tag {
            padding: 5px 10px;
            font-size: 0.74rem;
            border-radius: 999px;
            color: #a8dcff;
        }

        .info-box,
        .tip,
        .advanced-block .advanced-content {
            padding: 16px 18px;
            border-radius: 0;
        }

        .info-box strong {
            font-size: 0.92rem;
            margin-bottom: 6px;
        }

        .info-box {
            background: rgba(52, 152, 219, 0.1);
            border: 2px solid rgba(52, 152, 219, 0.4);
        }

        .tip {
            background: rgba(52, 152, 219, 0.1);
            border: 2px solid rgba(52, 152, 219, 0.4);
        }

        .points-table {
            border-radius: 0;
            background: rgba(255,255,255,0.03);
        }

        .points-table th,
        .points-table td {
            padding: 12px 14px;
            font-size: 0.84rem;
        }

        .points-table th {
            background: rgba(90,174,232,0.16);
            font-weight: 700;
            letter-spacing: 0.06em;
        }

        .points-table tr:hover {
            background: rgba(255,255,255,0.03);
        }

        .advanced-block {
            border-color: rgba(241, 196, 15, 0.18);
            background: rgba(241, 196, 15, 0.045);
        }

        .advanced-block summary {
            padding: 12px 16px;
            font-size: 0.84rem;
        }

        .updates-btn {
            top: 18px;
            right: 174px;
            padding: 8px 13px;
            font-size: 0.78rem;
            background: var(--surface-2);
            border: 1px solid var(--border-soft);
            color: var(--text-main);
            border-radius: 0;
            box-shadow: none;
        }

        .updates-btn:hover {
            background: rgba(90, 174, 232, 0.12);
            border-color: rgba(90, 174, 232, 0.4);
            box-shadow: none;
            transform: none;
        }

        .update-title {
            font-size: 0.94rem;
            font-weight: 700;
        }

        .empty-state .icon {
            font-size: 2.4rem;
        }

        footer {
            background: rgba(22, 29, 43, 0.92);
            padding: 16px 20px;
            font-size: 0.8rem;
        }

        @media (max-width: 768px) {
            body { padding: 0; }
            html { font-size: 14px; }
            .container {
                width: 100%;
                max-width: none;
                margin: 0;
                border-left: 0;
                border-right: 0;
                border-radius: 0;
            }
            .header-main { grid-template-columns: minmax(0, 1fr) minmax(112px, auto); gap: 8px 10px; }
            .header-meta { gap: 5px; }
            .credit { max-width: 142px; white-space: normal; line-height: 1.25; }
            .feedback-btn { white-space: normal; line-height: 1.25; }
            .topbar-inner { padding: 6px 10px; }
            .tab-content { padding: 20px 18px 24px; }
            .tab-button { font-size: 0.74rem; padding: 12px 10px; }
            .updates-btn {
                right: 16px;
                bottom: 18px;
                top: auto;
                border-radius: 999px;
            }
            .clock-time { font-size: 1.4rem; }
            .rose-number, .svs-number { font-size: 2rem; }
        }

        @media (max-width: 480px) {
            h1 { letter-spacing: 0.04em; }
            .card,
            .schedule-card,
            .user-card,
            .scenario-card,
            .feedback-list-item,
            .update-item { padding: 16px; }
            .duel-day-body { padding: 14px 16px; }
            .points-table th,
            .points-table td { padding: 10px 11px; }
        }

        /* ---- CALENDAR ---- */
        .cal-wrap { padding: 24px 32px; }
        .cal-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 20px; flex-wrap: wrap; gap: 10px; }
        .cal-title { font-size: 1.15em; font-weight: 700; color: #fff; min-width: 180px; }
        .cal-controls { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
        .cal-nav-btn { background: rgba(255,255,255,0.07); border: 1px solid rgba(255,255,255,0.11); color: #fff; border-radius: 0; padding: 6px 12px; cursor: pointer; font-size: 0.85em; transition: all 0.2s; }
        .cal-nav-btn:hover { background: rgba(90,174,232,0.18); border-color: rgba(90,174,232,0.35); }
        .cal-view-toggle { display: flex; border: 1px solid rgba(255,255,255,0.11); border-radius: 0; overflow: hidden; }
        .cal-view-btn { background: rgba(255,255,255,0.04); border: none; color: rgba(255,255,255,0.55); padding: 6px 14px; cursor: pointer; font-size: 0.8em; font-weight: 600; transition: all 0.2s; }
        .cal-view-btn.active { background: rgba(90,174,232,0.22); color: #fff; }
        .cal-add-btn { background: linear-gradient(135deg, #5aaee8, #3e86bd); border: none; color: #fff; padding: 7px 16px; border-radius: 0; cursor: pointer; font-size: 0.82em; font-weight: 700; transition: all 0.2s; letter-spacing: 0.2px; }
        .cal-add-btn:hover { opacity: 0.85; transform: translateY(-1px); }
        .cal-add-btn:disabled { opacity: 0.35; cursor: not-allowed; transform: none; }
        /* Mini week strip (in announcements tab) */
        .cal-mini-wrap { margin: 0 0 24px; padding: 16px 18px; background: rgba(255,255,255,0.03); border: 1px solid rgba(255,255,255,0.06); border-radius: 0; }
        .cal-mini-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 12px; gap: 10px; flex-wrap: wrap; }
        .cal-mini-title { font-size: 0.95em; font-weight: 700; color: #fff; letter-spacing: 0.3px; }
        .cal-mini-controls { display: flex; align-items: center; gap: 6px; flex-wrap: wrap; }
        .cal-mini-go { background: rgba(90,174,232,0.15); border: 1px solid rgba(90,174,232,0.3); color: #5aaee8; padding: 5px 12px; border-radius: 0; cursor: pointer; font-size: 0.78em; font-weight: 600; transition: all 0.2s; }
        .cal-mini-go:hover { background: rgba(90,174,232,0.25); color: #fff; }
        #calMiniGrid .cal-week-cell { min-height: 130px; }
        #calMiniGrid .cal-week-events-layer { top: 52px; grid-auto-rows: 28px; gap: 4px; }
        .cal-week-day-name .day-short { display: none; }
        @media(max-width:700px) {
            .cal-mini-wrap { padding: 10px 12px; margin-bottom: 18px; }
            .cal-mini-header { gap: 6px; }
            .cal-mini-title { font-size: 0.82em; flex: 1; min-width: 0; }
            .cal-mini-controls { gap: 4px; flex-wrap: nowrap; }
            .cal-mini-controls .cal-nav-btn { padding: 5px 9px; font-size: 0.78em; }
            .cal-mini-go { padding: 5px 10px; font-size: 0.72em; white-space: nowrap; }
            #calMiniGrid .cal-week-cell { min-height: 88px; }
            #calMiniGrid .cal-week-day-header { padding: 6px 2px 5px; }
            #calMiniGrid .cal-week-day-num { font-size: 0.95em; line-height: 1.3; }
            #calMiniGrid .cal-week-events-layer { top: 42px; grid-auto-rows: 26px; gap: 3px; padding: 4px 3px; }
            #calMiniGrid .cal-event-bar { padding: 3px 7px; font-size: 0.72em; line-height: 1.35; }
        }
        @media(max-width:480px) {
            .cal-week-day-name .day-full { display: none; }
            .cal-week-day-name .day-short { display: inline; font-size: 1.15em; }
            .cal-mini-title { width: 100%; flex: none; }
            .cal-mini-controls { width: 100%; justify-content: space-between; }
            #calMiniToday { display: none; }
            #calMiniGrid .cal-week-cell { min-height: 82px; }
            #calMiniGrid .cal-week-events-layer { top: 38px; }
        }
        /* Week view */
        .cal-week-row { position: relative; background: rgba(255,255,255,0.05); border-radius: 0; overflow: hidden; }
        .cal-week-cells { display: grid; grid-template-columns: repeat(7, 1fr); gap: 1px; }
        .cal-week-cell { background: rgba(26,26,46,0.97); min-height: 220px; cursor: pointer; transition: background 0.15s; }
        .cal-week-cell:hover { background: rgba(255,255,255,0.025); }
        .cal-week-cell.today { background: rgba(90,174,232,0.04); }
        .cal-week-day-header { padding: 10px 8px 8px; text-align: center; border-bottom: 1px solid rgba(255,255,255,0.05); pointer-events: none; }
        .cal-week-day-name { font-size: 0.68em; font-weight: 600; text-transform: uppercase; color: rgba(255,255,255,0.38); letter-spacing: 0.6px; }
        .cal-week-day-num { font-size: 1.15em; font-weight: 700; color: rgba(255,255,255,0.78); line-height: 1.5; }
        .cal-week-cell.today .cal-week-day-num { color: #5aaee8; }
        .cal-week-cell.today .cal-week-day-header { background: rgba(90,174,232,0.07); }
        .cal-week-events-layer {
            position: absolute; top: 60px; left: 0; right: 0;
            display: grid; grid-template-columns: repeat(7, 1fr);
            grid-auto-rows: 30px; gap: 4px; padding: 6px 5px;
            pointer-events: none;
        }
        /* Month view */
        .cal-month-grid { display: flex; flex-direction: column; gap: 1px; background: rgba(255,255,255,0.05); border-radius: 0; overflow: hidden; }
        .cal-month-labels { display: grid; grid-template-columns: repeat(7, 1fr); gap: 1px; }
        .cal-month-day-label { background: rgba(26,26,46,0.7); padding: 8px 4px; text-align: center; font-size: 0.68em; font-weight: 600; text-transform: uppercase; color: rgba(255,255,255,0.38); letter-spacing: 0.6px; }
        .cal-month-week { position: relative; }
        .cal-month-cells { display: grid; grid-template-columns: repeat(7, 1fr); gap: 1px; }
        .cal-month-cell { background: rgba(26,26,46,0.97); min-height: 110px; padding: 6px 4px 4px; cursor: pointer; transition: background 0.15s; }
        .cal-month-cell:hover { background: rgba(255,255,255,0.025); }
        .cal-month-cell.other-month { background: rgba(18,18,34,0.6); opacity: 0.45; pointer-events: none; }
        .cal-month-cell.today .cal-month-date-num { color: #5aaee8; background: rgba(90,174,232,0.13); border-radius: 50%; width: 22px; height: 22px; display: flex; align-items: center; justify-content: center; }
        .cal-month-date-num { font-size: 0.8em; font-weight: 700; color: rgba(255,255,255,0.65); margin-bottom: 3px; line-height: 1; pointer-events: none; }
        .cal-month-events-layer {
            position: absolute; top: 26px; left: 0; right: 0; bottom: 4px;
            display: grid; grid-template-columns: repeat(7, 1fr);
            grid-auto-rows: 24px; gap: 3px; padding: 0 3px;
            pointer-events: none; overflow: hidden;
        }
        /* Event bar (multi-day strip) */
        .cal-event-bar {
            pointer-events: auto; padding: 4px 9px; border-radius: 0;
            font-size: 0.82em; font-weight: 600; color: #fff;
            white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
            cursor: pointer; transition: opacity 0.15s; line-height: 1.4;
            align-self: stretch; min-width: 0; display: flex; align-items: center;
        }
        .cal-event-bar:hover { opacity: 0.82; }
        .cal-pill { display: inline-block; padding: 2px 7px; border-radius: 4px; font-size: 0.72em; font-weight: 600; color: #fff; white-space: nowrap; }
        .cal-pill-more { font-size: 0.66em; color: rgba(255,255,255,0.4); padding: 1px 4px; align-self: center; pointer-events: none; }
        /* Calendar create/edit modal */
        .cal-modal-overlay { display: none; position: fixed; inset: 0; background: rgba(0,0,0,0.65); z-index: 2000; align-items: center; justify-content: center; }
        .cal-modal-overlay.open { display: flex; }
        .cal-modal { background: #1a1a2e; border: 1px solid rgba(90,174,232,0.22); border-radius: 0; padding: 26px 26px 22px; width: 100%; max-width: 420px; box-shadow: 0 20px 60px rgba(0,0,0,0.65); }
        .cal-modal h3 { font-size: 1.05em; font-weight: 700; color: #fff; margin-bottom: 18px; }
        .cal-modal-field { margin-top: 13px; }
        .cal-modal-field:first-of-type { margin-top: 0; }
        .cal-modal-label { display: block; font-size: 0.75em; font-weight: 600; color: rgba(255,255,255,0.45); margin-bottom: 5px; text-transform: uppercase; letter-spacing: 0.3px; }
        .cal-modal input[type=text], .cal-modal input[type=date], .cal-modal input[type=time], .cal-modal textarea { width: 100%; background: rgba(255,255,255,0.06); border: 1px solid rgba(255,255,255,0.11); border-radius: 0; color: #fff; padding: 8px 11px; font-size: 0.88em; font-family: inherit; transition: border 0.2s; }
        .cal-modal input[type=text]:focus, .cal-modal input[type=date]:focus, .cal-modal input[type=time]:focus, .cal-modal textarea:focus { outline: none; border-color: rgba(90,174,232,0.5); }
        .cal-image-upload { display: flex; align-items: center; gap: 10px; }
        .cal-image-preview { width: 90px; aspect-ratio: 2 / 1; border-radius: 0; background: rgba(255,255,255,0.05) center/cover no-repeat; border: 1px dashed rgba(255,255,255,0.15); flex-shrink: 0; position: relative; overflow: hidden; }
        .cal-image-preview.has-img { border-style: solid; border-color: rgba(255,255,255,0.15); }
        .cal-image-btn { background: rgba(255,255,255,0.06); border: 1px solid rgba(255,255,255,0.11); color: rgba(255,255,255,0.8); padding: 6px 12px; border-radius: 0; cursor: pointer; font-size: 0.8em; transition: all 0.2s; }
        .cal-image-btn:hover { background: rgba(90,174,232,0.15); border-color: rgba(90,174,232,0.3); color: #fff; }
        .cal-image-remove { background: none; border: none; color: rgba(255,255,255,0.45); cursor: pointer; font-size: 0.78em; padding: 3px 7px; }
        .cal-image-remove:hover { color: #5aaee8; }
        .cal-detail-img { width: calc(100% + 30px); margin: -14px -15px 10px; aspect-ratio: 2 / 1; background: #000 center/cover no-repeat; border-radius: 10px 10px 0 0; }
        .cal-modal textarea { resize: vertical; min-height: 64px; }
        .cal-color-swatches { display: flex; flex-wrap: wrap; gap: 8px; align-items: center; }
        .cal-color-swatch { width: 26px; height: 26px; border-radius: 50%; cursor: pointer; border: 2px solid transparent; transition: all 0.15s; flex-shrink: 0; }
        .cal-color-swatch.selected { border-color: #fff; transform: scale(1.18); }
        .cal-custom-color { width: 72px; background: rgba(255,255,255,0.06); border: 1px solid rgba(255,255,255,0.11); border-radius: 0; color: #fff; padding: 4px 8px; font-size: 0.8em; font-family: monospace; }
        .cal-date-row { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
        .cal-modal-actions { display: flex; gap: 8px; margin-top: 18px; flex-wrap: wrap; }
        .cal-modal-save { flex: 1; background: linear-gradient(135deg, #5aaee8, #3e86bd); border: none; color: #fff; padding: 9px; border-radius: 0; font-weight: 700; font-size: 0.88em; cursor: pointer; transition: opacity 0.2s; min-width: 80px; }
        .cal-modal-save:hover { opacity: 0.85; }
        .cal-modal-save:disabled { opacity: 0.5; cursor: not-allowed; }
        .cal-modal-cancel { background: rgba(255,255,255,0.06); border: 1px solid rgba(255,255,255,0.1); color: rgba(255,255,255,0.6); padding: 9px 14px; border-radius: 0; font-size: 0.88em; cursor: pointer; transition: all 0.2s; }
        .cal-modal-cancel:hover { background: rgba(255,255,255,0.11); color: #fff; }
        .cal-modal-delete { background: rgba(90,174,232,0.1); border: 1px solid rgba(90,174,232,0.22); color: #5aaee8; padding: 9px 13px; border-radius: 0; font-size: 0.88em; cursor: pointer; transition: all 0.2s; }
        .cal-modal-delete:hover { background: rgba(90,174,232,0.2); }
        .cal-error { color: #5aaee8; font-size: 0.8em; margin-top: 10px; min-height: 16px; }
        /* Event detail popup */
        .cal-detail-popup { display: none; position: fixed; z-index: 2100; background: #1e1e38; border: 1px solid rgba(255,255,255,0.1); border-radius: 0; padding: 14px 15px; min-width: 240px; max-width: 310px; max-height: calc(100vh - 24px); overflow-y: auto; box-shadow: 0 8px 32px rgba(0,0,0,0.55); }
        .cal-detail-popup.open { display: block; }
        .cal-detail-head { display: flex; align-items: flex-start; gap: 8px; margin-bottom: 10px; }
        .cal-detail-dot { display: inline-block; width: 10px; height: 10px; border-radius: 50%; flex-shrink: 0; margin-top: 5px; }
        .cal-detail-title { font-weight: 700; font-size: 0.98em; color: #fff; word-break: break-word; flex: 1; line-height: 1.3; }
        .cal-detail-rows { display: flex; flex-direction: column; gap: 4px; padding-top: 2px; }
        .cal-detail-row { display: flex; flex-direction: column; gap: 1px; font-size: 0.82em; line-height: 1.4; }
        .cal-detail-tag { font-size: 0.7em; font-weight: 600; text-transform: uppercase; letter-spacing: 0.4px; color: rgba(255,255,255,0.35); }
        .cal-detail-val { color: rgba(255,255,255,0.85); }
        .cal-detail-desc { font-size: 0.82em; color: rgba(255,255,255,0.62); margin-top: 11px; padding-top: 10px; border-top: 1px solid rgba(255,255,255,0.07); white-space: pre-wrap; word-break: break-word; }
        .cal-detail-author { font-size: 0.74em; color: rgba(255,255,255,0.4); font-style: italic; margin-top: 10px; padding-top: 8px; border-top: 1px solid rgba(255,255,255,0.07); }
        .cal-detail-actions { display: flex; gap: 7px; align-items: center; margin-top: 10px; }
        .cal-detail-btn { font-size: 0.76em; padding: 4px 10px; border-radius: 0; cursor: pointer; font-weight: 600; border: none; transition: all 0.15s; }
        .cal-detail-edit { background: rgba(255,255,255,0.08); color: #fff; }
        .cal-detail-edit:hover { background: rgba(255,255,255,0.15); }
        .cal-detail-del { background: rgba(90,174,232,0.13); color: #5aaee8; }
        .cal-detail-del:hover { background: rgba(90,174,232,0.24); }
        .cal-detail-close { background: none; border: none; color: rgba(255,255,255,0.28); cursor: pointer; font-size: 0.78em; margin-left: auto; padding: 2px 6px; border-radius: 4px; }
        .cal-detail-close:hover { color: #fff; }
        .cal-login-notice { color: rgba(255,255,255,0.35); font-size: 0.82em; font-style: italic; margin-top: 12px; text-align: center; }
        @media(max-width:700px) {
            .cal-wrap { padding: 12px; }
            .cal-header { gap: 8px; }
            .cal-title { font-size: 0.95em; min-width: 100%; }
            .cal-controls { gap: 5px; flex-wrap: wrap; }
            .cal-controls .cal-nav-btn { padding: 5px 9px; font-size: 0.8em; }
            .cal-view-btn { padding: 5px 11px; font-size: 0.78em; }
            .cal-add-btn { padding: 6px 12px; font-size: 0.78em; }
            .cal-week-day-name { font-size: 0.7em; }
            .cal-week-day-num { font-size: 1em; }
            .cal-week-cell { min-height: 160px; }
            .cal-week-events-layer { top: 50px; grid-auto-rows: 26px; gap: 3px; padding: 4px 3px; }
            .cal-event-bar { font-size: 0.72em; padding: 3px 7px; line-height: 1.35; }
            .cal-month-cell { min-height: 72px; padding: 4px 3px; }
            .cal-month-date-num { font-size: 0.75em; }
            .cal-month-events-layer { top: 22px; grid-auto-rows: 20px; gap: 2px; }
            .cal-month-day-label { padding: 6px 2px; font-size: 0.6em; }
            .cal-pill-more { font-size: 0.6em; }
            .cal-modal { padding: 22px 18px 18px; max-width: calc(100vw - 28px); }
        }

        /* ---- 2026 TARGETED SHARPENING PASS ---- */
        .pinned-row {
            gap: 12px;
            margin-bottom: 22px;
        }

        .hub-status-strip {
            display: none;
            padding: 16px 18px 0;
            border-bottom: 1px solid rgba(90, 174, 232, 0.12);
            background: rgba(10, 14, 26, 0.12);
        }

        .hub-status-strip.visible {
            display: block;
        }

        .hub-status-strip .clock-block {
            margin-bottom: 12px;
        }

        .latest-update-tile {
            width: 100%;
            margin: 0 0 12px;
            padding: 14px 16px;
            display: grid;
            grid-template-columns: minmax(0, 1fr) auto;
            gap: 10px 14px;
            align-items: center;
            text-align: left;
            color: inherit;
            cursor: pointer;
        }

        .latest-update-tile:hover {
            background: var(--surface-3);
            border-color: rgba(98, 199, 255, 0.48);
        }

        .latest-update-label {
            color: #62c7ff;
            font-family: 'Orbitron', sans-serif;
            font-size: 0.68rem;
            font-weight: 800;
            letter-spacing: 0.12em;
            text-transform: uppercase;
        }

        .latest-update-title {
            margin-top: 4px;
            color: #fff;
            font-size: 1rem;
            font-weight: 850;
            line-height: 1.25;
        }

        .latest-update-meta {
            justify-self: end;
            color: rgba(220, 244, 255, 0.68);
            font-family: 'Orbitron', sans-serif;
            font-size: 0.68rem;
            font-weight: 750;
            letter-spacing: 0.08em;
            text-transform: uppercase;
            white-space: nowrap;
        }

        .latest-update-desc {
            grid-column: 1 / -1;
            color: rgba(230, 244, 255, 0.7);
            font-size: 0.82rem;
            line-height: 1.45;
        }

        .hub-status-strip .pinned-row {
            margin-bottom: 18px;
        }

        .duel-day-block,
        .rose-count-block,
        .svs-current-block,
        .latest-update-tile,
        .clock-block {
            border-radius: 0;
            box-shadow: none;
            background: #1a2132;
            border: 1px solid rgba(90, 174, 232, 0.34);
        }


        .duel-day-body,
        .rose-count-block,
        .svs-current-block {
            padding: 14px 16px;
        }

        .rose-label,
        .svs-label,
        .duel-day-header,
        .clock-label {
            font-size: 0.68rem;
            letter-spacing: 0.12em;
        }

        .rose-number,
        .svs-number {
            font-size: 2.25rem;
            letter-spacing: -0.03em;
        }

        .duel-day-theme {
            font-size: 1.58rem;
            line-height: 1.2;
        }

        .duel-day-items,
        .duel-day-tip,
        .duel-detail-row,
        .rose-buff,
        .svs-subtext,
        .clock-date,
        .clock-tz,
        .clock-offset-tag {
            font-size: 0.76rem;
        }

        .clock-tz, .clock-date {
            font-size: 0.7em;
        }

        .schedule-card,
        .scenario-card,
        .card,
        .info-box,
        .tip,
        .advanced-block,
        .update-item,
        .feedback-list-item,
        .user-card {
            border-radius: 0;
        }

        .schedule-card,
        .card,
        .scenario-card,
        .user-card,
        .cc-result-card,
        .cc-summary-box,
        .cc-best-box,
        .cc-side,
        .cc-form-block,
        .fc-formation-block {
            background: #1a2132;
            border: 1px solid rgba(255,255,255,0.08);
            box-shadow: none;
        }


        .schedule-card:hover,
        .card:hover,
        .update-item:hover,
        .stat-editable:hover {
            transform: none;
            box-shadow: none;
        }

        .btn,
        .btn-sm,
        .btn-edit,
        .btn-delete,
        .btn-cancel,
        .like-btn,
        .theme-tag,
        .update-tag,
        .duel-day-theme .duel-tag,
        .cc-run-btn,
        .cc-autofill-btn,
        .cc-unit-btn,
        .cc-power-tag,
        .cc-faction-pill,
        .cc-br-pill,
        .cc-go-pill,
        .cc-wd-pill,
        .cc-empty-pill {
            border-radius: 0 !important;
        }

        .btn,
        .btn-sm,
        .btn-edit,
        .btn-delete,
        .btn-cancel,
        .cc-run-btn,
        .cc-autofill-btn,
        .cc-unit-btn,
        .tool-btn,
        .emoji-btn,
        .sf-btn {
            min-height: 32px;
            padding: 7px 12px;
            font-size: 0.76rem;
            font-weight: 700;
            letter-spacing: 0.02em;
            box-shadow: none !important;
        }

        .btn-primary,
        .cc-run-btn,
        .cc-autofill-btn {
            background: #5aaee8;
            border: 1px solid #4f9fd5;
        }

        .btn-primary:hover,
        .cc-run-btn:hover,
        .cc-autofill-btn:hover {
            background: #4f9fd5;
        }

        .form-control,
        .language-selector select,
        .clock-tz-select,
        .search-input,
        .emoji-search {
            border-radius: 0;
            font-size: 0.82rem;
        }

        .points-table,
        .cc-perm-table {
            border-radius: 0;
            overflow: hidden;
            font-size: 0.82rem;
        }

        .points-table th,
        .points-table td,
        .cc-perm-table th,
        .cc-perm-table td {
            padding: 11px 12px;
        }

        .cc-wrap,
        .cc-formations,
        .cc-results,
        .scenario-grid,
        .schedule-grid {
            gap: 14px;
        }

        .cc-side-header,
        .cc-form-header,
        .cc-series-header,
        .cc-result-header {
            padding: 11px 14px;
            border-bottom: 1px solid rgba(255,255,255,0.08);
            background: rgba(255,255,255,0.03);
        }

        .cc-side-body,
        .cc-form-body,
        .cc-result-body,
        .cc-summary-box,
        .cc-best-box {
            padding: 14px;
        }

        .cc-form-label,
        .cc-summary-title,
        .cc-best-title,
        .cc-label,
        .cc-power-tag,
        .cc-slot-label,
        .cc-bi-label {
            text-transform: uppercase;
            letter-spacing: 0.08em;
            font-size: 0.68rem;
        }

        .cc-form-name,
        .cc-value,
        .cc-matchup-pow,
        .cc-matchup-result,
        .cc-series-block {
            font-size: 0.85rem;
        }

        .cc-slots-grid {
            gap: 10px;
        }

        .cc-slot,
        .cc-mini-slot,
        .cc-counter-node {
            border-radius: 0;
            box-shadow: none;
        }

        .cc-slot {
            padding: 10px 8px;
            border: 1px solid rgba(255,255,255,0.08);
            background: rgba(255,255,255,0.03);
        }

        .cc-slot-icon {
            width: 34px;
            height: 34px;
        }

        .cc-slot-label {
            margin-top: 6px;
            line-height: 1.2;
        }

        .cc-power-row,
        .cc-autofill-row,
        .cc-matchup-row,
        .cc-summary-stat {
            gap: 10px;
        }

        .cc-matchup-row {
            padding: 9px 0;
            border-bottom: 1px solid rgba(255,255,255,0.06);
        }

        .cc-perm-highlight {
            background: rgba(90, 174, 232, 0.08);
        }

        .advanced-block summary {
            padding: 12px 15px;
            font-size: 0.82rem;
            letter-spacing: 0.03em;
        }

        .advanced-block .advanced-content {
            padding: 10px 15px 15px;
            font-size: 0.84rem;
        }

        h2 {
            font-size: clamp(2.6rem, 3.4vw, 3.4rem);
            padding-bottom: 14px;
            margin-bottom: 24px;
        }

        h3 {
            font-size: clamp(1.65rem, 2.2vw, 2.15rem);
            margin: 34px 0 16px;
        }

        h4,
        .schedule-card h4,
        .scenario-card h4,
        .user-card h4 {
            font-size: 0.95rem;
            letter-spacing: 0.04em;
        }

        .card-title,
        .update-title {
            font-size: 1.02rem;
            line-height: 1.3;
        }

        .card-body,
        .update-desc,
        .tab-content,
        .tab-content li,
        .info-box,
        .tip,
        footer {
            font-size: 0.84rem;
        }

        /* SvS Planning */
        .svsp-gate { max-width: 520px; margin: 28px auto 34px; padding: 20px; border: 1px solid rgba(90,174,232,0.22); background: rgba(22,33,62,0.52); border-radius: 0; }
        .svsp-head { display: flex; align-items: center; justify-content: space-between; gap: 10px; margin-bottom: 8px; }
        .svsp-head h2 { margin: 0; }
        .svsp-help-btn { border: 1px solid rgba(90,174,232,0.62); background: rgba(90,174,232,0.22); color: #fff; border-radius: 999px; padding: 4px 9px; font-size: 0.72rem; font-weight: 900; cursor: pointer; box-shadow: 0 0 0 0 rgba(90,174,232,0.38); animation: svspHelpPulse 2.4s ease-in-out infinite; white-space: nowrap; }
        .svsp-help-btn:hover { border-color: rgba(255,255,255,0.38); background: rgba(90,174,232,0.34); transform: translateY(-1px); }
        .svsp-admin-strip .svsp-help-btn { border-radius: 0; padding: 8px 11px; font-size: 0.82rem; min-height: 36px; display: inline-flex; align-items: center; justify-content: center; }
        @keyframes svspHelpPulse { 0%, 100% { box-shadow: 0 0 0 0 rgba(90,174,232,0.32); } 50% { box-shadow: 0 0 0 6px rgba(90,174,232,0); } }
        .svsp-help-grid { display: grid; gap: 10px; margin-top: 8px; }
        .svsp-help-modal { max-width: min(980px, 96vw) !important; padding: 0; overflow: hidden; display: flex; flex-direction: column; }
        #svspHelpModal { z-index: 2600; }
        .svsp-help-top { position: sticky; top: 0; z-index: 2; display: flex; align-items: center; justify-content: space-between; gap: 12px; padding: 20px 24px 12px; background: rgba(26,26,46,0.98); border-bottom: 1px solid rgba(255,255,255,0.06); }
        .svsp-help-top h3 { margin: 0; }
        .svsp-help-close { width: 34px; height: 34px; border-radius: 0; border: 1px solid rgba(255,255,255,0.1); background: rgba(255,255,255,0.06); color: rgba(255,255,255,0.78); font-size: 1.1rem; line-height: 1; cursor: pointer; }
        .svsp-help-close:hover { color: #fff; background: rgba(90,174,232,0.18); border-color: rgba(90,174,232,0.32); }
        .svsp-help-body { padding: 16px 24px 0; overflow-y: auto; min-height: 0; }
        .svsp-help-section { margin-top: 12px; color: rgba(255,255,255,0.48); font-size: 0.72rem; font-weight: 900; text-transform: uppercase; letter-spacing: 0.08em; }
        .svsp-help-card { border: 1px solid rgba(255,255,255,0.08); background: rgba(0,0,0,0.16); border-radius: 0; padding: 9px 10px; }
        .svsp-help-card h4 { color: #5aaee8; margin: 0 0 4px; font-size: 0.86rem; }
        .svsp-help-card p { margin: 0; color: rgba(255,255,255,0.72); font-size: 0.78rem; line-height: 1.4; }
        .svsp-help-actions { position: sticky; bottom: 0; z-index: 2; margin-top: 0; padding: 14px 24px calc(14px + env(safe-area-inset-bottom)); background: rgba(26,26,46,0.98); border-top: 1px solid rgba(255,255,255,0.06); }
        .svsp-users-list { display: grid; gap: 8px; margin-top: 10px; max-height: 55vh; overflow-y: auto; }
        .svsp-user-row { display: grid; grid-template-columns: minmax(0, 1fr) auto; gap: 10px; align-items: center; border: 1px solid rgba(255,255,255,0.08); background: rgba(0,0,0,0.16); border-radius: 0; padding: 9px 10px; }
        .svsp-user-name { font-weight: 900; }
        .svsp-user-meta { color: rgba(255,255,255,0.42); font-size: 0.7rem; margin-top: 2px; }
        .svsp-user-perms { display: flex; gap: 10px; align-items: center; flex-wrap: wrap; justify-content: flex-end; }
        .svsp-user-perms label { display: inline-flex; align-items: center; gap: 5px; color: rgba(255,255,255,0.72); font-size: 0.74rem; font-weight: 800; }
        .svsp-user-perms input { accent-color: #5aaee8; }
        .svsp-gate.checking .svsp-unlock-form { display: none; }
        .svsp-loading { display: none; min-height: 210px; align-items: center; justify-content: center; text-align: center; color: rgba(255,255,255,0.62); font-weight: 700; }
        .svsp-loader-inner { display: grid; justify-items: center; gap: 10px; }
        .svsp-spinner { width: 34px; height: 34px; border-radius: 50%; border: 3px solid rgba(255,255,255,0.1); border-top-color: #5aaee8; animation: svspSpin 0.85s linear infinite; }
        .svsp-loader-title { color: #fff; font-weight: 900; font-size: 0.94rem; }
        .svsp-loader-sub { color: rgba(255,255,255,0.42); font-size: 0.76rem; font-weight: 700; }
        @keyframes svspSpin { to { transform: rotate(360deg); } }
        .svsp-gate.checking .svsp-loading { display: flex; }
        .svsp-gate-row { display: flex; gap: 10px; align-items: center; margin-top: 14px; }
        .svsp-gate-row input { flex: 1; }
        .svsp-shell { display: none; gap: 16px; align-items: start; }
        .svsp-shell.open { display: grid; grid-template-columns: minmax(0, 1fr) 330px; }
        .svsp-main-area { min-width: 0; }
        .svsp-toolbar { display: flex; gap: 8px; flex-wrap: wrap; align-items: center; margin: 14px 0; }
        .svsp-toolbar-spacer { flex: 1 1 auto; }
        .svsp-tool { border: 1px solid rgba(255,255,255,0.1); background: rgba(255,255,255,0.045); color: rgba(255,255,255,0.72); border-radius: 0; padding: 8px 11px; cursor: pointer; font-weight: 700; font-size: 0.82rem; }
        .svsp-tool.active, .svsp-tool:hover { background: rgba(90,174,232,0.16); color: #fff; border-color: rgba(90,174,232,0.32); }
        .svsp-tool:disabled { opacity: 0.38; cursor: not-allowed; }
        .svsp-marker-tool-group, .svsp-arrow-tool-group, .svsp-pill-tool-group { display: inline-flex; align-items: stretch; gap: 0; padding: 3px; border: 1px solid rgba(255,255,255,0.1); background: rgba(0,0,0,0.14); border-radius: 0; }
        .svsp-marker-tool-group.active, .svsp-arrow-tool-group.active, .svsp-pill-tool-group.active { border-color: rgba(90,174,232,0.34); background: rgba(90,174,232,0.08); }
        .svsp-marker-tool-group .svsp-tool, .svsp-arrow-tool-group .svsp-tool, .svsp-pill-tool-group .svsp-tool { border-radius: 0; border-color: transparent; background: transparent; }
        .svsp-marker-tool-group .svsp-tool:first-child, .svsp-arrow-tool-group .svsp-tool:first-child, .svsp-pill-tool-group .svsp-tool:first-child { border-top-right-radius: 0; border-bottom-right-radius: 0; }
        .svsp-marker-tool-group .svsp-tool:last-child, .svsp-arrow-tool-group .svsp-tool:last-child, .svsp-pill-tool-group .svsp-tool:last-child { border-top-left-radius: 0; border-bottom-left-radius: 0; border-left: 1px solid rgba(255,255,255,0.1); }
        .svsp-marker-tool-group .svsp-tool.active, .svsp-arrow-tool-group .svsp-tool.active, .svsp-pill-tool-group .svsp-tool.active { background: rgba(90,174,232,0.18); }
        .svsp-marker-tool-group select.svsp-tool, .svsp-arrow-tool-group select.svsp-tool, .svsp-pill-tool-group select.svsp-tool { color: #fff; background: rgba(255,255,255,0.06); color-scheme: dark; }
        .svsp-marker-tool-group select.svsp-tool option, .svsp-arrow-tool-group select.svsp-tool option, .svsp-pill-tool-group select.svsp-tool option { color: #fff; background: #141b30; }
        .svsp-tool.loading { display: inline-flex; align-items: center; gap: 6px; opacity: 0.75; cursor: wait; }
        .svsp-tool.loading::before { content: ""; width: 11px; height: 11px; border-radius: 50%; border: 2px solid rgba(255,255,255,0.22); border-top-color: currentColor; animation: svspSpin 0.8s linear infinite; }
        .svsp-admin-strip { display: none; align-items: center; justify-content: flex-end; gap: 8px; margin: -4px 0 12px; padding: 7px 9px; border: 1px solid rgba(255,255,255,0.07); background: rgba(0,0,0,0.14); border-radius: 0; }
        .svsp-admin-strip.open { display: flex; }
        .svsp-gate-demo { display: flex; align-items: center; gap: 10px; margin-top: 14px; padding-top: 14px; border-top: 1px solid rgba(255,255,255,0.08); }
        .svsp-gate-demo .svsp-tool { border-color: rgba(78,175,205,0.36); background: rgba(78,175,205,0.13); color: #dff7ff; }
        .svsp-gate-demo-note { color: rgba(255,255,255,0.56); font-size: 0.82rem; line-height: 1.35; }
        .svsp-demo-badge { display: inline-flex; align-items: center; min-height: 34px; padding: 0 10px; border-radius: 999px; border: 1px solid rgba(78,175,205,0.36); background: rgba(78,175,205,0.12); color: #dff7ff; font-size: 0.78rem; font-weight: 800; letter-spacing: 0.02em; text-transform: uppercase; }
        .svsp-name-row { display: flex; gap: 9px; align-items: center; margin: 8px 0 12px; }
        .svsp-name-row label { color: rgba(255,255,255,0.48); font-size: 0.78rem; font-weight: 700; white-space: nowrap; }
        .svsp-map { position: relative; aspect-ratio: 1024 / 826; overflow: hidden; border-radius: 0; border: 1px solid rgba(255,255,255,0.09); background: #1f2d4a; cursor: crosshair; }
        .svsp-map-actions { position: absolute; top: 8px; right: 8px; z-index: 5; display: flex; gap: 6px; pointer-events: auto; }
        .svsp-map-switch { position: absolute; top: 8px; left: 8px; z-index: 5; pointer-events: auto; }
        .svsp-map-action { border: 1px solid rgba(255,255,255,0.12); background: rgba(10,14,26,0.72); color: rgba(255,255,255,0.82); border-radius: 0; padding: 5px 8px; font-size: 0.7rem; font-weight: 900; cursor: pointer; backdrop-filter: blur(6px); }
        .svsp-map-action:hover:not(:disabled) { color: #fff; border-color: rgba(90,174,232,0.34); background: rgba(90,174,232,0.18); }
        .svsp-map-action:disabled { opacity: 0.38; cursor: not-allowed; }
        .svsp-map.move-mode { cursor: grab; }
        .svsp-map.move-mode.moving { cursor: grabbing; }
        .svsp-event-strip { display: flex; align-items: center; justify-content: space-between; gap: 10px; margin: 8px 0; padding: 7px 10px; border: 1px solid rgba(255,255,255,0.08); background: rgba(0,0,0,0.18); border-radius: 0; min-height: 36px; }
        .svsp-event-main { display: flex; align-items: center; gap: 8px; min-width: 0; font-size: 0.78rem; font-weight: 900; color: rgba(255,255,255,0.8); }
        .svsp-event-pill { color: #fff; border: 1px solid rgba(90,174,232,0.35); background: rgba(90,174,232,0.14); border-radius: 999px; padding: 2px 8px; white-space: nowrap; }
        .svsp-event-admin { display: none; align-items: center; gap: 6px; flex-wrap: wrap; justify-content: flex-end; }
        .svsp-event-admin input, .svsp-event-admin select { min-height: 28px; height: 28px; border-radius: 0; border: 1px solid rgba(255,255,255,0.11); background: rgba(255,255,255,0.06); color: #fff; padding: 3px 7px; font-size: 0.74rem; color-scheme: dark; }
        .svsp-event-admin input { width: 74px; }
        .svsp-event-admin input[type="date"] { width: 126px; }
        .svsp-event-admin input[type="time"] { width: 88px; }
        .svsp-event-admin button { min-height: 28px; padding: 4px 8px; border-radius: 0; font-size: 0.7rem; font-weight: 900; }
        .svsp-event-admin .svsp-reset-btn { background: rgba(90,174,232,0.12); border: 1px solid rgba(90,174,232,0.32); color: #ff9cad; }
        .svsp-map-base { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: fill; pointer-events: none; z-index: 1; }
        .svsp-svg { position: absolute; inset: 0; width: 100%; height: 100%; pointer-events: none; z-index: 2; }
        #svspItemsLayer { position: absolute; inset: 0; pointer-events: none; z-index: 3; }
        .svsp-map-highlight { filter: drop-shadow(0 0 5px #fff) drop-shadow(0 0 11px currentColor); animation: svspPulse 1.15s ease-in-out 2; }
        @keyframes svspPulse { 0%, 100% { opacity: 1; transform: translate(-50%,-50%) scale(1); } 50% { opacity: 1; transform: translate(-50%,-50%) scale(1.08); } }
        .svsp-svg .svsp-map-highlight { filter: drop-shadow(0 0 4px #fff) drop-shadow(0 0 8px currentColor); animation: svspSvgPulse 1.15s ease-in-out 2; }
        @keyframes svspSvgPulse { 0%, 100% { opacity: 1; } 50% { opacity: 1; stroke-width: 1.3; } }
        .svsp-marker, .svsp-pill { position: absolute; transform: translate(-50%,-50%); border-radius: 0; pointer-events: none; white-space: nowrap; }
        .svsp-marker.svsp-move-target, .svsp-pill.svsp-move-target { pointer-events: auto; cursor: grab; box-shadow: 0 0 0 3px rgba(241,196,15,0.18), 0 0 16px rgba(241,196,15,0.22); }
        .svsp-marker { color: #fff; font-weight: 900; text-shadow: 0 1px 2px rgba(0,0,0,0.5); }
        .svsp-marker { padding: 7px 10px; border: 2px solid currentColor; background: rgba(0,0,0,0.52); }
        .svsp-marker::before { content: ""; position: absolute; left: 50%; bottom: -9px; width: 12px; height: 12px; background: currentColor; transform: translateX(-50%) rotate(45deg); border-radius: 2px; }
        .svsp-marker.support, .svsp-marker.enemy { padding: 4px 7px; border-width: 1px; font-size: 0.68rem; font-weight: 800; color: rgba(255,255,255,0.72); background: rgba(10,14,26,0.34); text-shadow: none; }
        .svsp-marker.support::before, .svsp-marker.enemy::before { bottom: -5px; width: 7px; height: 7px; opacity: 0.72; }
        .svsp-marker.enemy { border-style: dashed; background: rgba(85,18,30,0.34); }
        .svsp-marker.support { background: rgba(12,70,58,0.34); }
        .svsp-pill { padding: 3px 7px; border: 1px solid currentColor; background: rgba(10,14,26,0.58); color: rgba(255,255,255,0.76) !important; font-size: 0.68rem; font-weight: 600; text-shadow: none; }
        .svsp-pill.dashed { border-style: dashed; }
        .svsp-suggestion { opacity: 0.62; }
        .svsp-participants { display: flex; gap: 6px; flex-wrap: wrap; align-items: center; margin-top: 8px; padding: 7px 9px; border: 1px solid rgba(255,255,255,0.07); background: rgba(0,0,0,0.16); border-radius: 0; font-size: 0.72rem; }
        .svsp-participants-label { color: rgba(255,255,255,0.42); font-weight: 800; margin-right: 2px; }
        .svsp-participant { font-weight: 900; padding: 2px 6px; border-radius: 999px; background: rgba(255,255,255,0.045); border: 1px solid rgba(255,255,255,0.055); }
        .svsp-participant.active::after { content: ""; display: inline-block; width: 6px; height: 6px; margin-left: 5px; border-radius: 50%; background: #5aaee8; box-shadow: 0 0 0 0 rgba(90,174,232,0.45); animation: svspActivePulse 1.6s ease-in-out infinite; vertical-align: middle; }
        @keyframes svspActivePulse { 0%, 100% { box-shadow: 0 0 0 0 rgba(90,174,232,0.45); } 50% { box-shadow: 0 0 0 4px rgba(90,174,232,0); } }
        .svsp-briefing { margin-top: 6px; border: 1px solid rgba(255,255,255,0.07); background: rgba(0,0,0,0.13); border-radius: 0; overflow: hidden; }
        .svsp-briefing.locked { border-color: rgba(245,185,76,0.2); }
        .svsp-briefing-head { display: grid; grid-template-columns: minmax(0, 1fr) auto; align-items: stretch; background: rgba(255,255,255,0.035); }
        .svsp-briefing-toggle { width: 100%; min-height: 28px; display: flex; align-items: center; justify-content: space-between; gap: 8px; border: 0; background: rgba(255,255,255,0.035); color: rgba(255,255,255,0.76); padding: 5px 9px; font-size: 0.72rem; font-weight: 900; cursor: pointer; }
        .svsp-briefing-toggle span { color: rgba(255,255,255,0.42); font-size: 0.7rem; }
        .svsp-briefing-lock { border: 0; border-left: 1px solid rgba(255,255,255,0.08); background: rgba(255,255,255,0.035); color: rgba(255,255,255,0.7); padding: 5px 9px; font-size: 0.7rem; font-weight: 900; cursor: pointer; }
        .svsp-briefing-lock.active { color: #ffd98a; background: rgba(245,185,76,0.12); }
        .svsp-briefing.collapsed .svsp-briefing-body { display: none; }
        .svsp-briefing.locked .svsp-briefing-form { opacity: 0.45; pointer-events: none; }
        .svsp-briefing.locked .svsp-briefing-pill.mine { cursor: default; }
        .svsp-briefing.locked .svsp-briefing-delete { display: none; }
        .svsp-briefing-body { display: grid; grid-template-columns: 1fr; gap: 7px; align-items: stretch; padding: 7px; }
        .svsp-briefing-form { display: grid; grid-template-columns: minmax(0, 1fr) auto; gap: 5px; min-width: 0; }
        .svsp-briefing-form input { min-height: 28px; height: 28px; border-radius: 0; border: 1px solid rgba(255,255,255,0.09); background: rgba(255,255,255,0.055); color: #fff; padding: 4px 7px; font-size: 0.74rem; min-width: 0; }
        .svsp-briefing-form button { min-height: 28px; border-radius: 0; border: 1px solid rgba(90,174,232,0.28); background: rgba(90,174,232,0.14); color: #fff; padding: 4px 8px; font-size: 0.7rem; font-weight: 900; cursor: pointer; }
        .svsp-custom-title { width: 100%; min-height: 28px; height: 28px; border-radius: 0; border: 1px solid rgba(255,255,255,0.09); background: rgba(255,255,255,0.055); color: #fff; padding: 4px 7px; font-size: 0.74rem; font-family: inherit; }
        .svsp-custom-textarea { width: 100%; min-height: 68px; max-height: 150px; resize: vertical; border-radius: 0; border: 1px solid rgba(255,255,255,0.09); background: rgba(255,255,255,0.055); color: #fff; padding: 7px 8px; font-size: 0.78rem; line-height: 1.35; font-family: inherit; }
        .svsp-custom-textarea:disabled { opacity: 0.45; cursor: not-allowed; }
        .svsp-custom-actions { display: flex; justify-content: flex-end; gap: 6px; align-items: center; }
        .svsp-custom-save { min-height: 28px; border-radius: 0; border: 1px solid rgba(90,174,232,0.28); background: rgba(90,174,232,0.14); color: #fff; padding: 4px 10px; font-size: 0.7rem; font-weight: 900; cursor: pointer; }
        .svsp-briefing-list { display: block; position: relative; overflow: visible; min-width: 0; line-height: 2.6; }
        .svsp-briefing-pill { display: inline; max-width: 100%; border: 1px solid currentColor; background: rgba(10,14,26,0.42); color: rgba(255,255,255,0.78); /*border-radius: 0;*/ padding: 6px 7px 6px 9px; margin-right: 6px; font-size: 0.72rem; font-weight: 650; cursor: default; user-select: none; white-space: normal; line-height: 1.35; -webkit-box-decoration-break: clone; box-decoration-break: clone; }
        .svsp-briefing-pill.mine { cursor: grab; }
        .svsp-briefing-pill.dragging { opacity: 0.34; cursor: grabbing; pointer-events: none; animation: svspBriefingPulse 0.8s ease-in-out infinite; }
        .svsp-briefing-pill.drop-target { background: rgba(90,174,232,0.1); box-shadow: inset 2px 0 0 currentColor, 0 0 0 3px rgba(90,174,232,0.08); animation: svspBriefingTarget 1.2s ease-in-out infinite; }
        .svsp-briefing-text { color: rgba(255,255,255,0.78); overflow-wrap: anywhere; }
        .svsp-briefing-delete { border: 0; background: rgba(255,255,255,0.07); color: rgba(255,255,255,0.62); border-radius: 999px; width: 16px; height: 16px; padding: 0; line-height: 16px; font-size: 0.7rem; font-weight: 900; cursor: pointer; }
        .svsp-briefing-delete:hover { color: #fff; background: rgba(90,174,232,0.28); }
        .svsp-briefing-insert-marker { position: absolute; z-index: 4; width: 3px; height: 1.6em; border-radius: 999px; background: #5aaee8; box-shadow: 0 0 0 3px rgba(90,174,232,0.14); pointer-events: none; transform: translateY(-50%); animation: svspBriefingMarker 1.05s ease-in-out infinite; }
        .svsp-briefing-ghost { position: fixed; z-index: 2600; pointer-events: none; max-width: min(320px, 82vw); border: 1px solid currentColor; background: rgba(10,14,26,0.92); color: rgba(255,255,255,0.84); border-radius: 0; padding: 5px 9px; font-size: 0.72rem; font-weight: 750; line-height: 1.25; box-shadow: 0 8px 24px rgba(0,0,0,0.35), 0 0 0 3px rgba(255,255,255,0.06); transform: translate(-50%, -140%) scale(1.02); transition: left 0.06s linear, top 0.06s linear, transform 0.14s ease-out; }
        @keyframes svspBriefingPulse { 0%, 100% { filter: brightness(1); } 50% { filter: brightness(1.35); } }
        @keyframes svspBriefingTarget { 0%, 100% { box-shadow: inset 2px 0 0 currentColor, 0 0 0 2px rgba(90,174,232,0.08); } 50% { box-shadow: inset 2px 0 0 currentColor, 0 0 0 5px rgba(90,174,232,0.16); } }
        @keyframes svspBriefingMarker { 0%, 100% { opacity: 0.68; transform: scaleY(0.86); } 50% { opacity: 1; transform: scaleY(1); } }
        .svsp-side { display: grid; gap: 14px; }
        .svsp-panel { border: 1px solid rgba(255,255,255,0.08); background: rgba(22,33,62,0.44); border-radius: 0; padding: 14px; }
        .svsp-panel h3 { margin: 0 0 10px; color: #fff; font-size: 1rem; }
        .svsp-panel-head { display: flex; align-items: center; justify-content: space-between; gap: 10px; margin-bottom: 10px; }
        .svsp-panel-head h3 { margin: 0; }
        .svsp-collapse-btn { width: 28px; height: 26px; display: grid; place-items: center; border: 1px solid rgba(255,255,255,0.09); background: rgba(255,255,255,0.045); color: rgba(255,255,255,0.72); border-radius: 0; cursor: pointer; font-weight: 900; line-height: 1; }
        .svsp-collapse-btn:hover { color: #fff; border-color: rgba(90,174,232,0.28); background: rgba(90,174,232,0.12); }
        .svsp-collapsible-body { display: block; }
        .svsp-panel.collapsed .svsp-collapsible-body { display: none; }
        .svsp-filter-row { display: flex; gap: 5px; flex-wrap: wrap; margin: -2px 0 9px; }
        .svsp-filter { border: 1px solid rgba(255,255,255,0.08); background: rgba(255,255,255,0.04); color: rgba(255,255,255,0.62); border-radius: 0; padding: 4px 7px; font-size: 0.68rem; font-weight: 800; cursor: pointer; }
        .svsp-filter.active, .svsp-filter:hover { color: #fff; border-color: rgba(90,174,232,0.32); background: rgba(90,174,232,0.13); }
        .svsp-mine-filter { display: inline-flex; align-items: center; gap: 5px; border: 1px solid rgba(255,255,255,0.08); background: rgba(255,255,255,0.04); color: rgba(255,255,255,0.68); border-radius: 0; padding: 4px 7px; font-size: 0.68rem; font-weight: 800; cursor: pointer; white-space: nowrap; }
        .svsp-mine-filter input { width: 13px; height: 13px; accent-color: #5aaee8; }
        .svsp-list { display: grid; gap: 8px; max-height: 300px; overflow-y: auto; }
        .svsp-entry { border: 1px solid rgba(255,255,255,0.07); background: rgba(0,0,0,0.18); border-radius: 0; padding: 6px 8px; font-size: 0.78rem; line-height: 1.28; }
        .svsp-edit-entry { cursor: pointer; transition: border-color 0.15s, background 0.15s; }
        .svsp-edit-entry:hover { border-color: rgba(90,174,232,0.3); background: rgba(90,174,232,0.08); }
        .svsp-edit-entry.moving { border-color: rgba(241,196,15,0.42); background: rgba(241,196,15,0.09); }
        .svsp-entry-top { display: flex; gap: 8px; justify-content: space-between; align-items: center; }
        .svsp-entry-top > span:last-child { display: inline-flex; gap: 5px; align-items: center; }
        .svsp-author { font-weight: 900; }
        .svsp-meta { color: rgba(255,255,255,0.42); font-size: 0.56rem; margin-top: 2px; opacity: 0.6; font-weight: 400; }
        .svsp-delete { border: 0; background: rgba(90,174,232,0.13); color: #ff8fa0; border-radius: 0; padding: 2px 6px; cursor: pointer; font-weight: 700; font-size: 0.68rem; }
        .svsp-edit-btn { border: 0; background: rgba(241,196,15,0.12); color: #ffd86a; border-radius: 0; padding: 2px 6px; cursor: pointer; font-weight: 800; font-size: 0.68rem; }
        .svsp-comments { display: flex; flex-direction: column; gap: 7px; max-height: 300px; overflow-y: auto; padding: 2px 2px 6px; }
        .svsp-comment { max-width: 86%; border: 1px solid rgba(255,255,255,0.07); background: rgba(0,0,0,0.2); border-radius: 0; padding: 7px 9px; font-size: 0.78rem; line-height: 1.32; align-self: flex-start; }
        .svsp-comment.mine { align-self: flex-end; background: rgba(90,174,232,0.1); border-color: rgba(90,174,232,0.2); }
        .svsp-comment.pinned { border-color: rgba(245,185,76,0.3); background: rgba(245,185,76,0.08); }
        .svsp-comment .svsp-entry-top { gap: 10px; }
        .svsp-comment-body { color: rgba(255,255,255,0.82); white-space: pre-wrap; word-break: break-word; }
        .svsp-comment-form { display: grid; grid-template-columns: minmax(0, 1fr) auto auto; gap: 7px; align-items: end; }
        .svsp-comment-form textarea { min-height: 40px; max-height: 96px; resize: vertical; }
        .svsp-comment-form .editor-strip { margin: 0; padding: 0; background: none; border: 0; }
        .svsp-comment-form .emoji-btn { width: 40px; min-height: 40px; }
        .svsp-comment-form .btn { min-height: 40px; padding: 8px 12px; white-space: nowrap; }
        .svsp-hint { color: rgba(255,255,255,0.42); font-size: 0.78rem; margin-top: 6px; min-height: 18px; display:none; }
        @media (max-width: 960px) {
            .svsp-shell.open { grid-template-columns: 1fr; }
        }
        @media (max-width: 700px) {
            body.svs-planning-active { padding: 0; overflow-x: hidden; }
            body.svs-planning-active .topbar-spacer { height: 40px; }
            body.svs-planning-active .container { width: 100%; max-width: none; border-radius: 0; box-shadow: none; }
            body.svs-planning-active header { display: none; }
            body.svs-planning-active .tabs {
                position: sticky;
                top: 40px;
                z-index: 150;
                display: flex;
                flex-wrap: nowrap;
                overflow-x: auto;
                gap: 0;
                border-bottom: 1px solid rgba(90,174,232,0.18);
                background: rgba(16,23,42,0.97);
                scrollbar-width: none;
                -webkit-overflow-scrolling: touch;
            }
            body.svs-planning-active .tabs::-webkit-scrollbar { display: none; }
            body.svs-planning-active .tab-button {
                flex: 0 0 auto !important;
                min-width: max-content !important;
                width: auto !important;
                padding: 10px 12px !important;
                font-size: 0.68rem !important;
                border-bottom: 0 !important;
            }
            body.svs-planning-active .tab-button.active { border-bottom: 2px solid #5aaee8 !important; }
            body.svs-planning-active .theme-tag { display: none; }
            body.svs-planning-active .topbar-inner { min-height: 40px; padding: 4px 8px; }
            body.svs-planning-active .topbar-brand { font-size: 0.78rem; }
            body.svs-planning-active .search-trigger { padding: 5px 8px; font-size: 0.72rem; }
            body.svs-planning-active .search-trigger kbd { display: none; }
            body.svs-planning-active .btn-sm { min-height: 28px; padding: 4px 9px; font-size: 0.72rem; }
            #svs-planning { padding: 10px 8px calc(92px + env(safe-area-inset-bottom, 0px)) !important; }
            #svs-planning h2 { font-size: 1.05rem; }
            .svsp-head { margin-bottom: 8px; }
            .svsp-help-btn { padding: 4px 8px; font-size: 0.68rem; }
            #svspHelpModal { align-items: flex-start; padding: calc(8px + env(safe-area-inset-top)) 8px 8px; }
            .svsp-help-modal { width: 100%; max-width: none !important; max-height: calc(100vh - 16px - env(safe-area-inset-top)); border-radius: 0; }
            .svsp-help-top { padding: 12px 14px 10px; }
            .svsp-help-body { padding: 10px 14px 0; }
            .svsp-help-actions { padding: 10px 14px calc(10px + env(safe-area-inset-bottom)); }
            .svsp-gate { margin: 16px 0 18px; padding: 14px; }
            .svsp-loading { min-height: 180px; }
            .svsp-unlock-form p { font-size: 0.82rem; line-height: 1.35; }
            .svsp-gate-row input { min-height: 40px; font-size: 16px; }
            .svsp-gate-row { flex-direction: column; align-items: stretch; gap: 8px; }
            .svsp-gate-row .btn { width: 100%; min-height: 38px; }
            .svsp-gate-demo { flex-direction: column; align-items: stretch; gap: 8px; }
            .svsp-gate-demo .svsp-tool { width: 100%; }
            .svsp-shell.open { gap: 10px; }
            .svsp-name-row { margin: 5px 0 8px; }
            .svsp-name-row label { font-size: 0.72rem; }
            .svsp-name-row input { min-height: 38px; font-size: 16px; }
            .svsp-toolbar {
                position: sticky;
                top: 79px;
                z-index: 80;
                flex-wrap: nowrap;
                overflow-x: auto;
                gap: 6px;
                margin: 8px -8px 8px;
                padding: 7px 8px;
                background: rgba(18,24,42,0.95);
                border-top: 1px solid rgba(255,255,255,0.06);
                border-bottom: 1px solid rgba(255,255,255,0.06);
                scrollbar-width: none;
                -webkit-overflow-scrolling: touch;
            }
            .svsp-toolbar::-webkit-scrollbar { display: none; }
            .svsp-toolbar-spacer { display: none; }
            .svsp-tool { flex: 0 0 auto; min-height: 36px; padding: 7px 10px; font-size: 0.74rem; }
            .svsp-marker-tool-group, .svsp-arrow-tool-group, .svsp-pill-tool-group { flex: 0 0 auto; padding: 2px; }
            .svsp-marker-tool-group .svsp-tool, .svsp-arrow-tool-group .svsp-tool, .svsp-pill-tool-group .svsp-tool { min-height: 34px; }
            .svsp-admin-strip { justify-content: stretch; gap: 6px; margin: -2px 0 8px; padding: 6px; overflow-x: auto; scrollbar-width: none; -webkit-overflow-scrolling: touch; }
            .svsp-admin-strip::-webkit-scrollbar { display: none; }
            .svsp-admin-strip .svsp-tool { flex: 1 0 auto; }
            .svsp-hint { min-height: 0; margin: 5px 0 7px; font-size: 0.7rem; line-height: 1.35; }
            .svsp-event-strip { align-items: stretch; flex-direction: column; margin: 7px 0; padding: 7px; }
            .svsp-event-main { font-size: 0.74rem; justify-content: space-between; }
            .svsp-event-admin { justify-content: stretch; }
            .svsp-event-admin input, .svsp-event-admin select { flex: 1 1 70px; min-width: 0; }
            .svsp-event-admin button { flex: 1 1 auto; }
            .svsp-map {
                margin: 0 -8px;
                border-left: 0;
                border-right: 0;
                border-radius: 0;
                touch-action: pan-y;
                min-height: min(72vw, 330px);
            }
            .svsp-map-actions { top: 6px; right: 6px; gap: 4px; }
            .svsp-map-action { padding: 4px 7px; font-size: 0.84rem; }
            .svsp-map.draw-mode { touch-action: none; }
            .svsp-marker { padding: 4px 7px; border-width: 1.5px; font-size: 0.68rem; }
            .svsp-marker::before { bottom: -6px; width: 8px; height: 8px; }
            .svsp-pill { max-width: 42vw; padding: 2px 6px; font-size: 0.6rem; white-space: normal; text-align: center; line-height: 1.15; }
            .svsp-participants { margin: 7px -2px 0; padding: 6px 7px; gap: 5px; font-size: 0.68rem; max-height: 74px; overflow-y: auto; }
            .svsp-participant { padding: 2px 5px; }
            .svsp-briefing { margin: 6px -2px 0; }
            .svsp-briefing-body { grid-template-columns: 1fr; gap: 6px; padding: 6px; }
            .svsp-briefing-form { grid-template-columns: minmax(0, 1fr) 52px; }
            .svsp-briefing-form input { font-size: 16px; }
            .svsp-custom-title, .svsp-custom-textarea { font-size: 16px; }
            .svsp-custom-textarea { min-height: 76px; }
            .svsp-briefing-list { padding-bottom: 2px; }
            .svsp-briefing-pill { max-width: 100%; font-size: 0.7rem; padding: 6px 6px 6px 8px; }
            .svsp-side { gap: 10px; margin-top: 8px; }
            .svsp-panel { padding: 10px; border-radius: 0; }
            .svsp-panel-head { margin-bottom: 0px; }
            .svsp-panel h3 { font-size: 0.92rem; }
            .svsp-collapse-btn { width: 30px; height: 28px; }
            .svsp-filter-row { flex-wrap: nowrap; overflow-x: auto; padding-bottom: 2px; scrollbar-width: none; -webkit-overflow-scrolling: touch; }
            .svsp-filter-row::-webkit-scrollbar { display: none; }
            .svsp-filter { flex: 0 0 auto; padding: 5px 8px; }
            .svsp-list { max-height: 210px; gap: 6px; }
            .svsp-entry { padding: 6px 7px; font-size: 0.75rem; }
            .svsp-comments { max-height: min(46vh, 390px); min-height: 140px; gap: 6px; padding-bottom: 4px; }
            .svsp-comment { max-width: 92%; padding: 7px 8px; font-size: 0.76rem; }
            .svsp-comment-form {
                position: fixed;
                left: max(8px, env(safe-area-inset-left, 0px));
                right: max(8px, env(safe-area-inset-right, 0px));
                bottom: calc(8px + env(safe-area-inset-bottom, 0px));
                z-index: 2200;
                grid-template-columns: minmax(0, 1fr) 38px auto;
                gap: 6px;
                padding: 7px;
                border: 1px solid rgba(255,255,255,0.1);
                border-radius: 0;
                background: rgba(16,23,42,0.96);
                box-shadow: 0 -8px 28px rgba(0,0,0,0.34);
            }
            .svsp-comment-form textarea { min-height: 38px; max-height: 88px; font-size: 16px; resize: none; padding: 8px 10px; line-height: 1.25; }
            .svsp-comment-form .emoji-btn { width: 38px; min-height: 38px; }
            .svsp-comment-form .btn { min-height: 38px; padding: 7px 10px; font-size: 0.78rem; }
            .svsp-user-row { grid-template-columns: 1fr; gap: 7px; }
            .svsp-user-perms { justify-content: flex-start; }
        }

        @media (max-width: 768px) {
            .hub-status-strip {
                padding: 12px 12px 0;
            }

            .latest-update-tile {
                grid-template-columns: 1fr;
                gap: 6px;
                padding: 12px;
            }

            .latest-update-meta {
                justify-self: start;
                font-size: 0.62rem;
            }

            .latest-update-title {
                font-size: 0.92rem;
            }

            .latest-update-desc {
                font-size: 0.74rem;
            }

            #tab-dashboard.active {
                display: grid;
                grid-template-columns: 1fr;
                align-items: stretch;
            }

            .duel-day-body,
            .rose-count-block,
            .svs-current-block,
            .cc-side-body,
            .cc-form-body,
            .cc-result-body,
            .cc-summary-box,
            .cc-best-box,
            .tab-content {
                padding: 12px;
            }

            .rose-number,
            .svs-number {
                font-size: 1.9rem;
            }

            .clock-block {
                order: 1;
                margin: 0 0 10px;
                padding: 0;
                background: transparent;
                border: 0;
            }

            .clock-row {
                display: grid;
                grid-template-columns: repeat(2, minmax(0, 1fr));
                gap: 8px;
            }

            .clock-cell {
                min-width: 0;
                padding: 10px 8px;
                border: 1px solid rgba(90, 174, 232, 0.24);
                background: rgba(21, 26, 42, 0.84);
                display: grid;
                grid-template-columns: 1fr;
                justify-items: center;
                gap: 4px;
                text-align: center;
            }

            .clock-cell:last-child {
                border: 1px solid rgba(90, 174, 232, 0.24);
            }

            .clock-settings-toggle {
                position: absolute;
                top: 4px;
                right: 4px;
                width: 24px;
                height: 24px;
                display: inline-grid;
                place-items: center;
                padding: 0;
                border: 1px solid rgba(90, 174, 232, 0.28);
                background: rgba(255, 255, 255, 0.04);
                color: rgba(220, 244, 255, 0.82);
                font-size: 0.78rem;
                line-height: 1;
                cursor: pointer;
            }

            .clock-settings-toggle:hover,
            .clock-settings-toggle[aria-expanded="true"] {
                color: #fff;
                background: rgba(90, 174, 232, 0.16);
                border-color: rgba(90, 174, 232, 0.46);
            }

            .clock-label,
            .rose-label,
            .svs-label {
                font-size: 0.56rem;
                line-height: 1.15;
                letter-spacing: 0.1em;
                margin: 0;
            }

            .clock-time {
                font-size: 1.22rem;
                line-height: 1;
                margin-top: 2px;
            }

            .clock-date,
            .clock-tz {
                font-size: 0.56rem;
                line-height: 1.15;
            }

            .clock-select-row {
                margin-top: 8px;
                padding: 8px;
                border: 1px solid rgba(90, 174, 232, 0.18);
                background: rgba(21, 26, 42, 0.58);
                display: grid;
                grid-template-columns: auto minmax(0, 1fr);
                gap: 6px;
                justify-content: stretch;
            }

            .clock-select-row:not(.open) {
                display: none;
            }

            .clock-select-row label {
                align-self: center;
                font-size: 0.56rem;
            }

            .clock-tz-select {
                max-width: none;
                width: 100%;
                min-width: 0;
                font-size: 0.72rem;
                padding: 6px 22px 6px 8px;
            }

            .clock-offset-tag {
                grid-column: 1 / -1;
                justify-self: center;
                font-size: 0.62rem;
                padding: 3px 8px;
            }

            .pinned-row {
                order: 2;
                display: flex;
                flex-direction: column;
                gap: 10px;
                margin-bottom: 14px;
            }

            .pinned-row > #duelDayBlock {
                order: 2;
            }

            .pinned-side-stats {
                order: 1;
                width: 100%;
                display: grid;
                grid-template-columns: repeat(2, minmax(0, 1fr));
                gap: 8px;
            }

            .rose-count-block,
            .svs-current-block {
                min-width: 0;
                width: auto;
                padding: 10px 8px;
                gap: 4px;
                flex-direction: column;
                align-items: center;
                justify-content: center;
                border: 1px solid rgba(90, 174, 232, 0.28);
                background: rgba(21, 26, 42, 0.84);
                text-align: center;
            }

            .rose-number,
            .svs-number {
                font-size: 1.55rem;
                line-height: 1;
                margin: 1px 0;
            }

            .rose-buff,
            .svs-subtext {
                font-size: 0.62rem;
                line-height: 1.2;
                letter-spacing: 0;
            }

            .btn,
            .btn-sm,
            .btn-edit,
            .btn-delete,
            .btn-cancel,
            .cc-run-btn,
            .cc-autofill-btn,
            .cc-unit-btn {
                min-height: 30px;
                padding: 6px 10px;
            }
        }

        /* GIFT CODES TAB */

            .gc-wrap { max-width: 1100px; margin: 0 auto; }
            .gc-header { display:flex; flex-wrap:wrap; gap:14px; align-items:center; justify-content:space-between; margin-bottom: 18px; padding: 14px 18px; background: rgba(90,174,232,0.08); border: 1px solid rgba(90,174,232,0.25); border-radius: 0; }
            .gc-header-text h2 { margin: 0 0 4px 0; font-size: 1.4em; color: #fff; }
            .gc-header-text p { margin: 0; opacity: 0.8; font-size: 0.9em; }
            .gc-meta { display:flex; gap: 10px; align-items:center; font-size: 0.85em; opacity: 0.75; }
            .gc-refresh-btn { background: linear-gradient(135deg, #5aaee8, #c93551); color:#fff; border:none; padding: 9px 16px; border-radius: 0; cursor:pointer; font-weight: 600; font-size: 0.88em; }
            .gc-refresh-btn:hover { filter: brightness(1.1); }
            .gc-refresh-btn:disabled { opacity: 0.5; cursor:wait; }
            .gc-grid { display:grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: 14px; }
            .gc-card { background: rgba(20,20,40,0.55); border: 1px solid rgba(90,174,232,0.35); border-radius: 0; padding: 16px; transition: transform 0.15s, border-color 0.15s; position:relative; overflow:hidden; }
            .gc-card:hover { transform: translateY(-2px); border-color: rgba(90,174,232,0.75); }
            .gc-card.verified::before { content: "✓ verified"; position:absolute; top: 8px; right: 8px; font-size: 0.65em; padding: 2px 7px; background: rgba(81,207,102,0.25); color: #6fdb6f; border-radius: 999px; font-weight: 600; letter-spacing: 0.5px; }
            .gc-card.inactive { border-color: rgba(255,255,255,0.1); opacity: 0.72; }
            .gc-card.inactive .gc-code { text-decoration: line-through; text-decoration-color: rgba(255,150,150,0.55); text-decoration-thickness: 2px; color: #c9ad6b; }
            .gc-card.inactive::before { content: attr(data-state-label); position:absolute; top: 8px; right: 8px; font-size: 0.65em; padding: 2px 8px; border-radius: 999px; font-weight: 700; letter-spacing: 0.5px; }
            .gc-card.inactive.reason-limit::before { background: rgba(255,170,80,0.25); color: #ffaf5a; }
            .gc-card.inactive.reason-manual::before { background: rgba(90,174,232,0.25); color: #ff8aa0; }
            .gc-card.inactive.reason-time::before { background: rgba(180,180,180,0.2); color: #ddd; }
            .gc-card.inactive.reason-auto::before { background: rgba(180,180,180,0.2); color: #ddd; }
            .gc-code-row { display:flex; align-items:center; gap: 10px; margin-bottom: 10px; }
            .gc-code { flex:1; font-family: ui-monospace, "Cascadia Code", Menlo, monospace; font-size: 1.25em; font-weight: 700; color: #ffd166; letter-spacing: 1px; word-break: break-all; }
            .gc-copy-btn { background: rgba(255,209,102,0.15); color: #ffd166; border: 1px solid rgba(255,209,102,0.4); border-radius: 0; padding: 6px 10px; cursor:pointer; font-size: 0.82em; font-weight: 600; flex-shrink: 0; }
            .gc-copy-btn:hover { background: rgba(255,209,102,0.28); }
            .gc-copy-btn.copied { background: rgba(81,207,102,0.25); color: #6fdb6f; border-color: rgba(81,207,102,0.5); }
            .gc-expire-btn { background: rgba(90,174,232,0.12); color: #ff8aa0; border: 1px solid rgba(90,174,232,0.35); border-radius: 0; padding: 6px 9px; cursor:pointer; font-size: 0.76em; font-weight: 600; flex-shrink: 0; line-height: 1; }
            .gc-expire-btn:hover { background: rgba(90,174,232,0.28); }
            .gc-limit-btn { background: rgba(255,170,80,0.12); color: #ffaf5a; border: 1px solid rgba(255,170,80,0.35); border-radius: 0; padding: 6px 9px; cursor:pointer; font-size: 0.76em; font-weight: 600; flex-shrink: 0; line-height: 1; }
            .gc-limit-btn:hover { background: rgba(255,170,80,0.28); }
            .gc-admin-actions { display:flex; gap: 4px; flex-shrink: 0; }
            .gc-rewards { font-size: 0.88em; opacity: 0.88; line-height: 1.45; margin-bottom: 10px; min-height: 1.2em; }
            .gc-rewards.empty { font-style: italic; opacity: 0.45; }
            .gc-footer { display:flex; justify-content:space-between; align-items:center; gap: 8px; font-size: 0.76em; opacity: 0.65; padding-top: 10px; border-top: 1px solid rgba(255,255,255,0.08); }
            .gc-source-pill { display: inline-block; padding: 2px 8px; border-radius: 999px; background: rgba(255,255,255,0.08); }
            .gc-expiry { color: #ff9a8b; }
            .gc-empty { text-align:center; padding: 60px 20px; opacity: 0.6; }
            .gc-redeem-link { display:block; margin-top: 18px; text-align:center; padding: 11px 18px; background: rgba(90,174,232,0.15); border: 1px dashed rgba(90,174,232,0.5); border-radius: 0; color: #ffd166; text-decoration:none; font-weight: 600; }
            .gc-redeem-link:hover { background: rgba(90,174,232,0.25); }
            .gc-admin-box { margin-top: 22px; padding: 16px; background: rgba(0,0,0,0.25); border: 1px dashed rgba(90,174,232,0.4); border-radius: 0; }
            .gc-admin-box h3 { margin: 0 0 12px 0; font-size: 1em; color: #ffd166; }
            .gc-admin-row { display:grid; grid-template-columns: 1.2fr 2fr 1.5fr auto; gap: 8px; align-items:center; }
            .gc-admin-row input { padding: 8px 10px; border-radius: 0; border: 1px solid rgba(255,255,255,0.15); background: rgba(0,0,0,0.3); color: #fff; font-size: 0.88em; }
            .gc-admin-row button { padding: 8px 14px; background: #5aaee8; color: #fff; border: none; border-radius: 0; cursor:pointer; font-weight: 600; }
            .gc-admin-list { margin-top: 14px; max-height: 280px; overflow-y:auto; }
            .gc-admin-item { display:flex; gap:10px; align-items:center; padding: 6px 8px; font-size: 0.85em; border-bottom: 1px solid rgba(255,255,255,0.06); }
            .gc-admin-item .code-cell { font-family: monospace; color: #ffd166; flex: 1; }
            .gc-admin-item .src-cell { font-size: 0.8em; opacity: 0.6; }
            .gc-admin-item.expired .code-cell { text-decoration: line-through; opacity: 0.5; }
            .gc-admin-item button { background: rgba(255,255,255,0.08); color: #ddd; border: 1px solid rgba(255,255,255,0.15); padding: 4px 9px; font-size: 0.78em; border-radius: 0; cursor:pointer; }
            .gc-admin-item button:hover { background: rgba(90,174,232,0.25); color: #fff; }
            @media (max-width: 640px) {
                .gc-admin-row { grid-template-columns: 1fr; }
            }

            /* DISCORD GROUP TAB */

            .dg-feed { display: grid; gap: 10px; margin-top: 16px; }
            .dg-feed-tools { display: flex; align-items: center; justify-content: space-between; gap: 10px; margin-top: 12px; flex-wrap: wrap; }
            .dg-author-filters { display: flex; gap: 6px; flex-wrap: wrap; min-width: 0; }
            .dg-author-chip { border: 1px solid rgba(90,174,232,0.24); background: rgba(90,174,232,0.08); color: rgba(230,244,255,0.72); padding: 5px 9px; font-size: 0.72rem; cursor: pointer; font-family: 'Orbitron', sans-serif; }
            .dg-author-chip.active { background: rgba(90,174,232,0.24); color: #fff; border-color: rgba(119,211,255,0.52); }
            .dg-message { display: grid; grid-template-columns: 42px minmax(0, 1fr); gap: 10px; padding: 12px 14px; background: rgba(21, 26, 42, 0.72); border: 1px solid rgba(90,174,232,0.18); border-radius: 0; }
            .dg-message.hidden { opacity: 0.48; border-style: dashed; }
            .dg-message.pinned { border-color: rgba(127,226,255,0.46); background: linear-gradient(135deg, rgba(55,110,155,0.42), rgba(21,26,42,0.74)); box-shadow: inset 0 0 0 1px rgba(255,255,255,0.03); }
            .dg-pinned-wrap { display: grid; gap: 8px; margin-top: 14px; }
            .dg-pinned-label { color: #7fe2ff; font-family: 'Orbitron', sans-serif; font-size: 0.72rem; text-transform: uppercase; letter-spacing: .06em; }
            .dg-avatar { width: 38px; height: 38px; border-radius: 50%; background: rgba(90,174,232,0.16); display: grid; place-items: center; color: #62c7ff; font-weight: 900; font-family: 'Orbitron', sans-serif; overflow: hidden; }
            .dg-avatar img { width: 100%; height: 100%; object-fit: cover; }
            .dg-head { display: flex; align-items: baseline; gap: 8px; flex-wrap: wrap; }
            .dg-author { color: #fff; font-weight: 850; }
            .dg-time { color: rgba(220,244,255,0.45); font-size: 0.74rem; font-family: 'Orbitron', sans-serif; }
            .dg-admin-actions { display: inline-flex; gap: 5px; margin-left: auto; flex-wrap: wrap; }
            .dg-admin-btn { padding: 3px 8px; border: 1px solid rgba(90,174,232,0.28); background: rgba(90,174,232,0.1); color: #dff7ff; font-size: 0.68rem; cursor: pointer; }
            .dg-hidden-badge { color: #ffaf5a; font-size: 0.68rem; font-family: 'Orbitron', sans-serif; text-transform: uppercase; }
            .dg-pinned-badge { color: #7fe2ff; font-size: 0.68rem; font-family: 'Orbitron', sans-serif; text-transform: uppercase; }
            .dg-roles { display: inline-flex; gap: 5px; flex-wrap: wrap; }
            .dg-role-badge { border: 1px solid color-mix(in srgb, var(--role-color, #7fe2ff), transparent 38%); background: color-mix(in srgb, var(--role-color, #7fe2ff), transparent 84%); color: #e9fbff; padding: 2px 6px; font-size: 0.64rem; font-family: 'Orbitron', sans-serif; }
            .dg-text { margin-top: 5px; color: rgba(230,244,255,0.82); line-height: 1.45; white-space: pre-wrap; overflow-wrap: anywhere; }
            .dg-attachments { display: flex; gap: 8px; flex-wrap: wrap; margin-top: 9px; }
            .dg-attachment { display: inline-flex; align-items: center; gap: 6px; max-width: 100%; padding: 6px 9px; border: 1px solid rgba(90,174,232,0.22); background: rgba(90,174,232,0.08); color: #dff7ff; text-decoration: none; font-size: 0.78rem; overflow-wrap: anywhere; }
            .dg-attachment.image { padding: 0; overflow: hidden; display: block; width: min(180px, 45vw); border: 1px solid rgba(127,226,255,0.28); cursor: zoom-in; }
            .dg-attachment.image img { display: block; width: 100%; aspect-ratio: 16 / 10; height: auto; object-fit: cover; }
            .dg-feed.compact { gap: 7px; }
            .dg-feed.compact .dg-message { grid-template-columns: 30px minmax(0, 1fr); padding: 8px 10px; }
            .dg-feed.compact .dg-avatar { width: 28px; height: 28px; font-size: .72rem; }
            .dg-feed.compact .dg-text { margin-top: 3px; line-height: 1.32; font-size: .88rem; }
            .dg-feed.compact .dg-attachment.image { width: 120px; }
            .dg-lightbox { position: fixed; inset: 0; z-index: 9999; display: none; place-items: center; padding: 22px; background: rgba(4,8,15,0.84); backdrop-filter: blur(7px); }
            .dg-lightbox.active { display: grid; }
            .dg-lightbox-inner { max-width: min(92vw, 980px); max-height: 88vh; display: grid; gap: 10px; }
            .dg-lightbox img { max-width: 100%; max-height: 82vh; object-fit: contain; border: 1px solid rgba(127,226,255,0.24); background: rgba(0,0,0,0.3); }
            .dg-lightbox-caption { color: rgba(230,244,255,0.72); font-size: .85rem; text-align: center; }
            .dg-empty { padding: 34px 18px; text-align: center; color: rgba(230,244,255,0.55); border: 1px dashed rgba(90,174,232,0.24); background: rgba(21,26,42,0.36); }
            #dgAdminPanel .dg-admin-tabs { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; margin: 0 0 12px; padding: 8px; border: 1px solid rgba(90,174,232,0.16); background: rgba(9,14,24,0.36); }
            #dgAdminPanel .dg-admin-tab { min-height: 36px; padding: 7px 10px; border: 1px solid rgba(90,174,232,0.18); background: rgba(90,174,232,0.08); color: rgba(223,247,255,0.72); cursor: pointer; font-family: 'Orbitron', sans-serif; font-size: 0.72rem; font-weight: 800; text-transform: uppercase; flex: 1 1 120px; }
            #dgAdminPanel .dg-admin-tab.active { background: rgba(90,174,232,0.24); border-color: rgba(127,226,255,0.48); color: #fff; }
            #dgAdminPanel .dg-admin-panel { display: none; }
            #dgAdminPanel .dg-admin-panel.active { display: block; }
            #dgAdminPanel .dg-admin-panel h3 { margin-bottom: 14px; }
            @media (max-width: 560px) {
                .dg-feed-tools { align-items: stretch; }
                .dg-author-filters { width: 100%; }
                .dg-message { grid-template-columns: 34px minmax(0, 1fr); padding: 10px; }
                .dg-avatar { width: 32px; height: 32px; }
                #dgAdminPanel .dg-admin-tabs { gap: 6px; padding: 6px; }
                #dgAdminPanel .dg-admin-tab { flex-basis: calc(50% - 6px); font-size: 0.66rem; }
            }

            /* DISCORD RELAY TAB */

            .dr-wrap { max-width: 1100px; margin: 0 auto; }
            .dr-header { padding: 16px 20px; background: rgba(88,101,242,0.10); border: 1px solid rgba(88,101,242,0.35); border-radius: 0; margin-bottom: 18px; }
            .dr-header h2 { margin: 0 0 6px 0; color: #fff; font-size: 1.4em; }
            .dr-header p { margin: 0; opacity: 0.85; font-size: 0.92em; line-height: 1.5; }
            .dr-status { display:inline-block; padding: 3px 10px; border-radius: 999px; font-size: 0.78em; font-weight: 600; letter-spacing: 0.5px; margin-left: 6px; }
            .dr-status.live { background: rgba(81,207,102,0.2); color: #6fdb6f; }
            .dr-status.warn { background: rgba(255,170,80,0.2); color: #ffaf5a; }
            .dr-status.idle { background: rgba(255,255,255,0.08); color: #aaa; }
            .dr-card { background: rgba(20,20,40,0.5); border: 1px solid rgba(255,255,255,0.1); border-radius: 0; padding: 16px 18px; margin-bottom: 16px; }
            .dr-card h3 { margin: 0 0 14px 0; font-size: 1.02em; color: #ffd166; display:flex; align-items:center; gap: 10px; }
            .dr-card h3 .num { display:inline-flex; width: 24px; height: 24px; border-radius: 50%; background: rgba(255,209,102,0.2); color: #ffd166; align-items:center; justify-content:center; font-size: 0.85em; }
            .dr-card .right-btn { margin-left: auto; }
            .dr-form { display:grid; grid-template-columns: 160px 1fr auto; gap: 8px 12px; align-items:center; margin-bottom: 10px; }
            .dr-form label { font-size: 0.85em; opacity: 0.85; }
            .dr-form input { padding: 8px 10px; border-radius: 0; border: 1px solid rgba(255,255,255,0.15); background: rgba(0,0,0,0.35); color: #fff; font-size: 0.88em; font-family: ui-monospace, monospace; }
            .dr-form .full { grid-column: 1 / -1; }
            @media (max-width: 700px) { .dr-form { grid-template-columns: 1fr; } .dr-form .full { grid-column: auto; } }
            .dr-mini-btn { padding: 8px 12px; background: rgba(255,209,102,0.15); color: #ffd166; border: 1px solid rgba(255,209,102,0.4); border-radius: 0; cursor:pointer; font-size: 0.82em; font-weight: 600; white-space:nowrap; }
            .dr-mini-btn:hover { background: rgba(255,209,102,0.28); }
            .dr-mini-btn:disabled { opacity: 0.5; cursor:wait; }
            .dr-mini-btn.primary { background: #5865f2; color: #fff; border-color: #5865f2; }
            .dr-mini-btn.primary:hover { filter: brightness(1.15); background: #5865f2; }
            .dr-mini-btn.danger { background: rgba(90,174,232,0.15); color: #ff8aa0; border-color: rgba(90,174,232,0.4); }
            .dr-mini-btn.danger:hover { background: rgba(90,174,232,0.28); }
            .dr-help { font-size: 0.82em; opacity: 0.72; line-height: 1.55; margin-top: 8px; }
            .dr-help strong { color: #ffd166; }
            .dr-help a { color: #7da7f7; }
            .dr-test-result { margin-top: 12px; padding: 10px 12px; border-radius: 0; font-size: 0.86em; line-height: 1.5; display:none; }
            .dr-test-result.ok { background: rgba(81,207,102,0.12); border: 1px solid rgba(81,207,102,0.35); color: #b6e8b6; }
            .dr-test-result.err { background: rgba(90,174,232,0.15); border: 1px solid rgba(90,174,232,0.4); color: #ffb3bf; }
            .dr-url-box { display:flex; gap: 6px; margin-bottom: 6px; }
            .dr-url-input { flex:1; font-family: ui-monospace, monospace; font-size: 0.78em; padding: 8px 10px; background: rgba(0,0,0,0.4); color: #ddd; border: 1px solid rgba(255,255,255,0.12); border-radius: 0; }
            .dr-codeblock { background: rgba(0,0,0,0.55); border: 1px solid rgba(255,255,255,0.1); border-radius: 0; padding: 11px 13px; font-family: ui-monospace, "Cascadia Code", monospace; font-size: 0.82em; line-height: 1.5; white-space: pre-wrap; overflow-x:auto; color: #d4d4d8; }
            .dr-log { max-height: 420px; overflow-y:auto; display:grid; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); gap: 8px; padding: 4px; }
            .dr-code-block { background: rgba(20,20,40,0.55); border: 1px solid rgba(255,209,102,0.25); border-radius: 0; padding: 10px 12px; display:flex; flex-direction:column; gap: 4px; transition: border-color 0.15s; }
            .dr-code-block:hover { border-color: rgba(255,209,102,0.55); }
            .dr-code-block.dup { border-color: rgba(255,255,255,0.08); opacity: 0.7; }
            .dr-code-block .code { font-family: ui-monospace, "Cascadia Code", Menlo, monospace; font-size: 1.05em; font-weight: 700; color: #ffd166; letter-spacing: 0.5px; word-break: break-all; }
            .dr-code-block .meta { font-size: 0.74em; opacity: 0.7; display:flex; justify-content:space-between; align-items:center; gap: 6px; }
            .dr-code-block .badge-new { font-size: 0.65em; padding: 1px 6px; background: rgba(81,207,102,0.2); color: #6fdb6f; border-radius: 999px; font-weight: 600; }
            .dr-code-block .badge-dup { font-size: 0.65em; padding: 1px 6px; background: rgba(255,255,255,0.08); color: #aaa; border-radius: 999px; }
            .dr-log-empty { grid-column: 1 / -1; padding: 20px; opacity: 0.5; text-align:center; }
            .dr-noadmin { padding: 30px; text-align:center; opacity: 0.6; }
            .dr-status-row { display:flex; flex-wrap:wrap; gap: 12px; padding: 10px 12px; background: rgba(0,0,0,0.25); border-radius: 0; margin-bottom: 12px; font-size: 0.84em; }
            .dr-status-row span { opacity: 0.8; }
            .dr-status-row strong { color: #fff; font-weight: 600; }

            /* HEROES DATABASE */

                .hdb-layout { display: flex; gap: 20px; min-height: 500px; }
                .hdb-sidebar { width: 260px; flex-shrink: 0; display: flex; flex-direction: column; max-height: calc(100vh - 200px); position: sticky; top: 80px; }
                .hdb-sidebar-scroll { overflow-y: auto; flex: 1; padding-right: 4px; }
                .hdb-sidebar-scroll::-webkit-scrollbar { width: 4px; }
                .hdb-sidebar-scroll::-webkit-scrollbar-thumb { background: rgba(90,174,232,0.3); border-radius: 4px; }
                .hdb-faction-group { margin-bottom: 8px; }
                .hdb-faction-header {
                    display: flex; align-items: center; gap: 8px; padding: 7px 12px;
                    background: rgba(255,255,255,0.03); border-radius: 0;
                    margin-bottom: 3px; user-select: none;
                }
                .hdb-faction-header img { width: 18px; height: 18px; object-fit: contain; }
                .hdb-faction-header .hdb-fh-name { font-weight: 700; font-size: 0.8em; letter-spacing: 0.5px; }
                .hdb-faction-header .hdb-fh-count { font-size: 0.68em; color: #666; margin-left: auto; }
                .hdb-faction-header.hdb-br .hdb-fh-name { color: #5aaee8; }
                .hdb-faction-header.hdb-wod .hdb-fh-name { color: #3498db; }
                .hdb-faction-header.hdb-goo .hdb-fh-name { color: #cca22e; }
                .hdb-hero-list { display: flex; flex-direction: column; gap: 1px; }
                .hdb-hero-item {
                    display: flex; align-items: center; gap: 8px; padding: 5px 10px;
                    border-radius: 0; cursor: pointer; transition: all 0.15s; border-left: 3px solid transparent;
                }
                .hdb-hero-item:hover { background: rgba(255,255,255,0.05); }
                .hdb-hero-item.hdb-active { background: rgba(90,174,232,0.12); border-left-color: #5aaee8; }
                .hdb-hero-item.hdb-active.hdb-wod-active { background: rgba(52,152,219,0.12); border-left-color: #3498db; }
                .hdb-hero-item.hdb-active.hdb-goo-active { background: rgba(204,162,46,0.12); border-left-color: #cca22e; }
                .hdb-hero-thumb {
                    width: 30px; height: 30px; border-radius: 50%; object-fit: cover; flex-shrink: 0;
                    border: 2px solid rgba(255,255,255,0.08); background: rgba(255,255,255,0.04);
                }
                .hdb-hero-thumb-fallback {
                    width: 30px; height: 30px; border-radius: 50%; flex-shrink: 0;
                    display: flex; align-items: center; justify-content: center;
                    font-weight: 800; font-size: 0.75em; background: rgba(255,255,255,0.06);
                    border: 2px solid rgba(255,255,255,0.08);
                }
                .hdb-hi-info { flex: 1; min-width: 0; }
                .hdb-hi-name { font-weight: 700; font-size: 0.8em; color: #ddd; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
                .hdb-hi-sub { font-size: 0.65em; color: #666; }
                .hdb-hi-tier {
                    font-size: 0.65em; font-weight: 800; padding: 2px 6px; border-radius: 0;
                    flex-shrink: 0; line-height: 1.2;
                }
                .hdb-tier-splus { background: rgba(46,204,113,0.15); color: #2ecc71; }
                .hdb-tier-s { background: rgba(255,165,0,0.15); color: #ffa500; }
                .hdb-tier-aplus { background: rgba(155,89,182,0.15); color: #9b59b6; }
                .hdb-tier-a { background: rgba(155,89,182,0.12); color: #9b59b6; }
                .hdb-tier-bplus { background: rgba(100,149,237,0.12); color: #6495ed; }
                .hdb-tier-b { background: rgba(100,149,237,0.1); color: #6495ed; }
                .hdb-tier-c { background: rgba(149,165,166,0.12); color: #95a5a6; }

                /* ---- Right panel ---- */
                .hdb-detail { flex: 1; min-width: 0; }
                .hdb-empty-detail {
                    display: flex; flex-direction: column; align-items: center; justify-content: center;
                    min-height: 400px; color: #555; text-align: center; padding: 40px;
                }
                .hdb-empty-detail .hdb-empty-icon { font-size: 3em; margin-bottom: 12px; opacity: 0.4; }

                /* Hero Bio Card - compact horizontal */
                .hdb-bio {
                    display: flex; gap: 18px; margin-bottom: 18px;
                    background: rgba(22,33,62,0.6); border-radius: 0; padding: 16px;
                    border: 1px solid rgba(255,255,255,0.06);
                }
                .hdb-portrait-wrap { width: 300px; flex-shrink: 0; }
                .hdb-portrait {
                    width: 300px; height: 306px; border-radius: 0; object-fit: cover;
                    border: 2px solid rgba(255,255,255,0.1); background: rgba(255,255,255,0.04); display: block;
                }
                .hdb-portrait-fallback {
                    width: 300px; height: 306px; border-radius: 0;
                    display: flex; align-items: center; justify-content: center;
                    font-size: 3em; font-weight: 900; color: #444;
                    background: linear-gradient(135deg, rgba(22,33,62,0.8), rgba(26,26,46,0.9));
                    border: 2px solid rgba(255,255,255,0.1);
                }
                .hdb-bio-info { flex: 1; min-width: 0; }
                .hdb-bio-name { font-size: 1.4em; font-weight: 800; margin-bottom: 4px; }
                .hdb-bio-name.hdb-name-br { color: #5aaee8; }
                .hdb-bio-name.hdb-name-wod { color: #3498db; }
                .hdb-bio-name.hdb-name-goo { color: #cca22e; }
                .hdb-bio-tags { display: flex; flex-wrap: wrap; gap: 4px; margin-bottom: 10px; }
                .hdb-tag {
                    padding: 2px 10px; border-radius: 0; font-size: 0.72em; font-weight: 700;
                    display: inline-flex; align-items: center; gap: 4px;
                }
                .hdb-tag-faction { border: 1px solid; }
                .hdb-tag-br { background: rgba(90,174,232,0.12); color: #5aaee8; border-color: rgba(90,174,232,0.3); }
                .hdb-tag-wod { background: rgba(52,152,219,0.12); color: #3498db; border-color: rgba(52,152,219,0.3); }
                .hdb-tag-goo { background: rgba(204,162,46,0.12); color: #cca22e; border-color: rgba(204,162,46,0.3); }
                .hdb-tag-rarity { background: rgba(255,165,0,0.12); color: #ffa500; border: 1px solid rgba(255,165,0,0.3); }
                .hdb-tag-rarity-a { background: rgba(155,89,182,0.12); color: #9b59b6; border: 1px solid rgba(155,89,182,0.3); }
                .hdb-tag-rarity-b { background: rgba(100,149,237,0.12); color: #6495ed; border: 1px solid rgba(100,149,237,0.3); }
                .hdb-tag-role { background: rgba(255,255,255,0.06); color: #aaa; border: 1px solid rgba(255,255,255,0.1); }
                .hdb-bio-stats {
                    display: grid; grid-template-columns: 1fr 1fr 1fr 1fr; gap: 6px;
                }
                .hdb-stat {
                    padding: 6px 10px; border-radius: 0; background: rgba(255,255,255,0.03);
                    border: 1px solid rgba(255,255,255,0.05);
                }
                .hdb-stat-label { font-size: 0.6em; font-weight: 700; text-transform: uppercase; letter-spacing: 0.8px; color: #555; margin-bottom: 1px; }
                .hdb-stat-value { font-size: 0.82em; font-weight: 700; color: #ddd; }

                /* Skills - 2-col grid, compact */
                .hdb-section-title {
                    font-size: 1em; font-weight: 800; color: #5aaee8; margin-bottom: 10px;
                    padding-bottom: 6px; border-bottom: 2px solid rgba(90,174,232,0.2);
                    display: flex; align-items: center; gap: 6px;
                }
                .hdb-section-title::before { content: none; }
                .hdb-skills-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; margin-bottom: 18px; }
                .hdb-skill-card {
                    background: rgba(22,33,62,0.6); border-radius: 0; padding: 12px;
                    border: 1px solid rgba(255,255,255,0.06);
                }
                .hdb-skill-num {
                    display: inline-flex; align-items: center; justify-content: center;
                    width: 22px; height: 22px; border-radius: 0; font-size: 0.7em; font-weight: 800;
                    margin-right: 6px; flex-shrink: 0;
                }
                .hdb-skill-num-1 { background: rgba(46,204,113,0.15); color: #2ecc71; }
                .hdb-skill-num-2 { background: rgba(52,152,219,0.15); color: #3498db; }
                .hdb-skill-num-3 { background: rgba(255,165,0,0.15); color: #ffa500; }
                .hdb-skill-num-4 { background: rgba(155,89,182,0.15); color: #9b59b6; }
                .hdb-skill-header { display: flex; align-items: center; margin-bottom: 4px; }
                .hdb-skill-name { font-weight: 700; font-size: 0.8em; color: #ccc; }
                .hdb-skill-desc { font-size: 0.78em; color: #888; line-height: 1.5; padding-left: 28px; }
                .hdb-skill-stars { display: flex; gap: 2px; margin-left: auto; padding-left: 6px; }
                .hdb-star { color: #444; font-size: 0.6em; }
                .hdb-star.hdb-star-lit { color: #f1c40f; }

                /* Recommendations - compact */
                .hdb-recs-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; margin-bottom: 12px; }
                .hdb-rec-box {
                    background: rgba(22,33,62,0.6); border-radius: 0; padding: 12px;
                    border: 1px solid rgba(255,255,255,0.06);
                }
                .hdb-rec-title { font-weight: 700; font-size: 0.82em; color: #5aaee8; margin-bottom: 4px; }
                .hdb-rec-text { font-size: 0.78em; color: #a0a0a0; line-height: 1.5; }
                .hdb-rec-text strong { color: #ccc; }

                /* Filters bar */
                .hdb-filters { padding: 0 0 8px 0; border-bottom: 1px solid rgba(255,255,255,0.06); margin-bottom: 6px; flex-shrink: 0; }
                .hdb-filter-row { display: flex; flex-wrap: wrap; gap: 4px; margin-bottom: 4px; }
                .hdb-sort-btn {
                    padding: 4px 12px; border-radius: 0; font-size: 0.72em; font-weight: 700;
                    border: 1px solid rgba(90,174,232,0.3); background: rgba(90,174,232,0.1);
                    color: #5aaee8; cursor: pointer; transition: all 0.15s; white-space: nowrap;
                }
                .hdb-sort-btn:hover { background: rgba(90,174,232,0.2); }
                .hdb-pill {
                    padding: 6px 16px; border-radius: 0; font-size: 0.68em; font-weight: 700;
                    border: 1px solid rgba(255,255,255,0.1); background: rgba(255,255,255,0.04);
                    color: #777; cursor: pointer; transition: all 0.15s; white-space: nowrap;
                }
                .hdb-pill:hover { border-color: rgba(90,174,232,0.3); color: #ccc; }
                .hdb-pill.hdb-pill-active { background: rgba(90,174,232,0.15); color: #5aaee8; border-color: rgba(90,174,232,0.4); }

                /* Nav arrows in bio */
                .hdb-nav-arrow {
                    position: absolute; top: 50%; transform: translateY(-50%);
                    width: 32px; height: 60px; border-radius: 0;
                    background: rgba(255,255,255,0.06); border: 1px solid rgba(255,255,255,0.1);
                    color: #888; font-size: 1.4em; cursor: pointer; transition: all 0.15s;
                    display: flex; align-items: center; justify-content: center; z-index: 2; padding: 0;
                }
                .hdb-nav-arrow:hover { background: rgba(90,174,232,0.15); border-color: rgba(90,174,232,0.4); color: #5aaee8; }
                .hdb-nav-prev { left: -4px; }
                .hdb-nav-next { right: -4px; }
                .hdb-bio { position: relative; }
                /* Desktop: hide mobile-only elements */
                .hdb-hero-strip { display: none; }
                .hdb-collapse-toggle { display: none; }
                .hdb-sidebar.hdb-collapsed .hdb-sidebar-scroll { display: block; }
                .hdb-sidebar.hdb-collapsed .hdb-filters .hdb-filter-row:not(:first-child) { display: flex; }

                @media (max-width: 900px) {
                    .hdb-skills-grid { grid-template-columns: 1fr; }
                    .hdb-recs-grid { grid-template-columns: 1fr; }
                    .hdb-bio-stats { grid-template-columns: 1fr 1fr; }
                }
                @media (max-width: 768px) {
                    .hdb-layout { flex-direction: column; }
                    .hdb-sidebar {
                        width: 100%; max-height: none; position: static;
                        background: rgba(18, 18, 34, 0.97); backdrop-filter: blur(10px);
                        border-bottom: 1px solid rgba(255,255,255,0.06);
                        margin: -20px -20px 12px -20px; padding: 8px 16px 6px;
                        width: calc(100% + 40px); z-index: 20;
                        transition: box-shadow 0.2s;
                    }
                    .hdb-sidebar.hdb-fixed {
                        position: fixed; top: 52px; left: 0; right: 0;
                        width: 100%; margin: 0; padding: 8px 16px 6px;
                        border-radius: 0; box-shadow: 0 4px 20px rgba(0,0,0,0.5);
                    }
                    .hdb-spacer { display: none; }
                    .hdb-spacer.hdb-spacer-active { display: block; }
                    /* Collapsed: hide full list, show strip */
                    .hdb-sidebar.hdb-collapsed .hdb-sidebar-scroll { display: none; }
                    .hdb-sidebar.hdb-collapsed .hdb-filters .hdb-filter-row:not(:first-child) { display: none; }
                    /* Hero strip - horizontal scroll of avatars */
                    .hdb-hero-strip {
                        display: none; overflow-x: auto; gap: 6px; padding: 4px 0;
                        -webkit-overflow-scrolling: touch; scrollbar-width: none;
                    }
                    .hdb-hero-strip::-webkit-scrollbar { display: none; }
                    .hdb-sidebar.hdb-collapsed .hdb-hero-strip { display: flex; }
                    .hdb-strip-item {
                        width: 36px; height: 36px; border-radius: 50%; flex-shrink: 0;
                        border: 2px solid rgba(255,255,255,0.1); cursor: pointer;
                        overflow: hidden; transition: border-color 0.15s; position: relative;
                    }
                    .hdb-strip-item img { width: 100%; height: 100%; object-fit: cover; display: block; }
                    .hdb-strip-item.hdb-strip-active { border-color: #5aaee8; box-shadow: 0 0 8px rgba(90,174,232,0.4); }
                    .hdb-strip-item.hdb-strip-active-wod { border-color: #3498db; box-shadow: 0 0 8px rgba(52,152,219,0.4); }
                    .hdb-strip-item.hdb-strip-active-goo { border-color: #cca22e; box-shadow: 0 0 8px rgba(204,162,46,0.4); }
                    .hdb-strip-fb { display: flex; align-items: center; justify-content: center; font-size: 0.65em; font-weight: 800; background: rgba(255,255,255,0.06); color: #888; }
                    .hdb-strip-sep {
                        width: 2px; height: 24px; flex-shrink: 0; align-self: center;
                        background: rgba(255,255,255,0.08); border-radius: 1px;
                    }
                    /* Toggle button */
                    .hdb-collapse-toggle {
                        display: flex; align-items: center; justify-content: center;
                        background: none; border: none; color: #666; font-size: 0.7em;
                        cursor: pointer; padding: 2px 8px; margin-left: auto;
                        font-weight: 700; letter-spacing: 0.5px;
                    }
                    .hdb-collapse-toggle:hover { color: #5aaee8; }
                    .hdb-sidebar-scroll { max-height: 200px; }
                    .hdb-bio { flex-direction: column; align-items: center; text-align: center; padding: 16px 40px; }
                    .hdb-portrait-wrap { width: 300px; }
                    .hdb-portrait { width: 300px; height: 306px; }
                    .hdb-portrait-fallback { width: 300px; height: 306px; font-size: 2.5em; }
                    .hdb-bio-tags { justify-content: center; }
                    .hdb-bio-stats { grid-template-columns: 1fr 1fr; }
                    .hdb-nav-arrow { width: 28px; height: 44px; font-size: 1.2em; }
                    .hdb-nav-prev { left: 4px; }
                    .hdb-nav-next { right: 4px; }
                }
            
        /* ---- ADVANCED GUIDE BLOCKS ---- */
        .advanced-block {
            margin: 18px 0;
            border: 1px solid rgba(241, 196, 15, 0.22);
            border-radius: 0;
            overflow: hidden;
            background: rgba(241, 196, 15, 0.06);
        }
        .advanced-block summary {
            list-style: none;
            cursor: pointer;
            padding: 14px 18px;
            font-weight: 700;
            color: #f1c40f;
            display: flex;
            align-items: center;
            justify-content: space-between;
            gap: 12px;
            user-select: none;
        }
        .advanced-block summary::-webkit-details-marker { display: none; }
        .advanced-block summary::after {
            content: '▾';
            color: #f1c40f;
            font-size: 1.15em;
            transition: transform 0.2s ease;
        }
        .advanced-block[open] summary::after { transform: rotate(180deg); }
        .advanced-block .advanced-content {
            padding: 0 18px 18px;
            color: #d9d9d9;
            border-top: 1px solid rgba(255,255,255,0.06);
            background: rgba(0,0,0,0.08);
        }
        .theme-tag.advanced {
            background: rgba(241,196,15,0.18);
            color: #f1c40f;
            border-color: rgba(241,196,15,0.28);
        }
        .scenario-grid {
            display: grid;
            grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
            gap: 16px;
            margin: 20px 0;
        }
        .scenario-card {
            background: rgba(241, 196, 15, 0.15);
            border-radius: 0;
            border: 2px solid rgba(241, 196, 15, 0.4);
            padding: 18px;
        }
        .scenario-card h4 {
            margin: 0 0 10px;
            color: #fff;
            font-size: 1.05em;
        }
        .scenario-card .label {
            display: inline-block;
            font-size: 0.75em;
            font-weight: 700;
            text-transform: uppercase;
            letter-spacing: 0.8px;
            margin-bottom: 10px;
            color: #f1c40f;
        }
        .mini-divider {
            height: 1px;
            background: rgba(255,255,255,0.08);
            margin: 14px 0;
        }

        /* FORMATION CALCULATOR */

                .fc-formations { display: flex; flex-direction: column; gap: 28px; max-width: 100%; overflow: hidden; }
                .fc-formation-block {
                    background: rgba(22, 33, 62, 0.6); border-radius: 0; overflow: hidden;
                    border: 2px solid rgba(255,255,255,0.06); transition: border-color 0.3s;
                    max-width: 100%;
                }
                .fc-formation-block.fc-active { border-color: rgba(90, 174, 232, 0.5); }
                .fc-form-header {
                    display: flex; align-items: center; justify-content: space-between;
                    padding: 14px 20px; background: rgba(90, 174, 232, 0.12);
                    border-bottom: 1px solid rgba(90, 174, 232, 0.15);
                    cursor: pointer; user-select: none;
                }
                .fc-form-header h3 { margin: 0; font-size: 1.1em; color: #fff; }
                .fc-form-header h3::before { content: none; }
                .fc-form-toggle { font-size: 1.2em; color: #5aaee8; transition: transform 0.3s; }
                .fc-form-toggle.collapsed { transform: rotate(-90deg); }
                .fc-form-body { padding: 20px; overflow: hidden; }
                .fc-form-body.collapsed { display: none; }
                .fc-slot-row-label {
                    font-size: 0.75em; font-weight: 700; text-transform: uppercase;
                    letter-spacing: 1.5px; color: #888; padding: 4px 0; margin-bottom: 6px;
                }
                .fc-slots { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; margin-bottom: 18px; }
                .fc-back-row { grid-template-columns: 1fr 1fr 1fr; }
                .fc-slot {
                    background: rgba(255,255,255,0.04); border: 2px dashed rgba(255,255,255,0.12);
                    border-radius: 0; padding: 12px; cursor: pointer;
                    transition: all 0.2s; min-height: 72px;
                    display: flex; align-items: center; gap: 10px; position: relative;
                }
                .fc-slot:hover { border-color: rgba(90, 174, 232, 0.4); background: rgba(90, 174, 232, 0.06); }
                .fc-slot.fc-filled { border-style: solid; border-color: rgba(255,255,255,0.12); }
                .fc-slot.fc-filled.fc-br { border-color: rgba(90, 174, 232, 0.4); background: rgba(90, 174, 232, 0.08); }
                .fc-slot.fc-filled.fc-wod { border-color: rgba(52, 152, 219, 0.4); background: rgba(52, 152, 219, 0.08); }
                .fc-slot.fc-filled.fc-goo { border-color: rgba(222, 211, 48, 0.4); background: rgba(204, 178, 46, 0.08); }
                .fc-slot-empty { color: #555; font-size: 0.85em; text-align: center; width: 100%; }
                .fc-slot-icon {
                    width: 40px; height: 40px; border-radius: 0; flex-shrink: 0;
                    display: flex; align-items: center; justify-content: center; font-size: 1.3em; font-weight: 800;
                    overflow: hidden;
                }
                .fc-faction-img { display: block; image-rendering: auto; }
                .fc-faction-img-inline { width: 20px; height: 20px; object-fit: contain; vertical-align: middle; margin-right: 3px; display: inline-block; }
                .fc-slot-icons { display: flex; align-items: center; gap: 6px; flex-shrink: 0; }
                .fc-slot-hero-img {
                    width: 40px; height: 40px; border-radius: 50%; object-fit: cover;
                    border: 2px solid rgba(255,255,255,0.1); background: rgba(255,255,255,0.04);
                }
                .fc-slot-hero-img.fc-br-border { border-color: rgba(90,174,232,0.4); }
                .fc-slot-hero-img.fc-wod-border { border-color: rgba(52,152,219,0.4); }
                .fc-slot-hero-img.fc-goo-border { border-color: rgba(222, 211, 48, 0.4); }
                .fc-ho-hero-img {
                    width: 36px; height: 36px; border-radius: 50%; object-fit: cover;
                    border: 2px solid rgba(255,255,255,0.08); background: rgba(255,255,255,0.04); flex-shrink: 0;
                }
                .fc-presets { margin-bottom: 24px; }
                .fc-presets h4 { font-size: 1.15em; text-transform: uppercase; letter-spacing: 1px; color: #5aaee8; margin-bottom: 10px; }
                .fc-presets h4::before { content: none; }
                .fc-preset-grid { display: flex; flex-wrap: wrap; gap: 8px; }
                .fc-preset-btn {
                    padding: 8px 16px; border-radius: 0; border: 1px solid rgba(255,255,255,0.1);
                    background: rgba(255,255,255,0.04); color: #ccc; font-size: 0.9em; font-weight: 600;
                    cursor: pointer; transition: all 0.2s; display: inline-flex; align-items: center; gap: 6px;
                }
                .fc-preset-btn:hover { background: rgba(90,174,232,0.12); border-color: rgba(90,174,232,0.4); color: #fff; }
                .fc-preset-btn .fc-preset-dot { width: 8px; height: 8px; border-radius: 50%; flex-shrink: 0; }
                .fc-grade-banner {
                    border-radius: 0; padding: 16px 20px; margin-bottom: 14px;
                    display: flex; align-items: center; gap: 16px; border: 2px solid;
                }
                .fc-grade-letter {
                    width: 52px; height: 52px; border-radius: 0; display: flex;
                    align-items: center; justify-content: center; font-size: 1.6em; font-weight: 900;
                    flex-shrink: 0; letter-spacing: -1px;
                }
                .fc-grade-info { flex: 1; min-width: 0; }
                .fc-grade-title { font-weight: 800; font-size: 1.2em; margin-bottom: 2px; }
                .fc-grade-desc { font-size: 0.9em; opacity: 0.8; line-height: 1.4; }
                .fc-grade-s { background: rgba(46,204,113,0.08); border-color: rgba(46,204,113,0.4); }
                .fc-grade-s .fc-grade-letter { background: rgba(46,204,113,0.2); color: #2ecc71; }
                .fc-grade-s .fc-grade-title { color: #2ecc71; }
                .fc-grade-s .fc-grade-desc { color: #8be8b8; }
                .fc-grade-a { background: rgba(52,152,219,0.08); border-color: rgba(52,152,219,0.4); }
                .fc-grade-a .fc-grade-letter { background: rgba(52,152,219,0.2); color: #3498db; }
                .fc-grade-a .fc-grade-title { color: #3498db; }
                .fc-grade-a .fc-grade-desc { color: #8ec8e8; }
                .fc-grade-b { background: rgba(241,196,15,0.08); border-color: rgba(241,196,15,0.4); }
                .fc-grade-b .fc-grade-letter { background: rgba(241,196,15,0.2); color: #f1c40f; }
                .fc-grade-b .fc-grade-title { color: #f1c40f; }
                .fc-grade-b .fc-grade-desc { color: #f0dc7e; }
                .fc-grade-c { background: rgba(231,76,60,0.08); border-color: rgba(231,76,60,0.4); }
                .fc-grade-c .fc-grade-letter { background: rgba(231,76,60,0.2); color: #e74c3c; }
                .fc-grade-c .fc-grade-title { color: #e74c3c; }
                .fc-grade-c .fc-grade-desc { color: #f0a8a0; }
                .fc-synergy-highlight {
                    background: rgba(46,204,113,0.06); border: 1px solid rgba(46,204,113,0.2);
                    border-radius: 0; padding: 10px 14px; margin: 4px 0;
                }
                .fc-buff-stacked { margin-left: 10px; padding-left: 10px; border-left: 2px solid rgba(255,255,255,0.06); }
                fc-buff-stacked .fc-buff-icon {display: none !important;}

                .fc-slot-icon.fc-br-icon { background: rgba(90,174,232,0.2); color: #5aaee8; }
                .fc-slot-icon.fc-wod-icon { background: rgba(52,152,219,0.2); color: #3498db; }
                .fc-slot-icon.fc-goo-icon { background: rgba(167, 132, 50, 0.4); color: #cca22e; }
                .fc-slot-info { flex: 1; min-width: 0; }
                .fc-slot-name { font-weight: 700; font-size: 1em; color: #fff; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
                .fc-slot-meta { font-size: 0.75em; color: #999; }
                .fc-slot-clear {
                    position: absolute; top: 4px; right: 6px;
                    width: 22px; height: 22px; border-radius: 50%;
                    background: rgba(231,76,60,0.25); border: none; color: #e74c3c;
                    font-size: 0.7em; cursor: pointer; display: flex;
                    align-items: center; justify-content: center;
                    opacity: 0; transition: opacity 0.2s;
                }
                .fc-slot:hover .fc-slot-clear, .fc-slot:active .fc-slot-clear { opacity: 1; }
                @media (pointer: coarse) { .fc-slot-clear { opacity: 0.8; } }
                .fc-results { margin-top: 4px; }
                .fc-result-section {
                    background: rgba(22, 33, 62, 0.5); border-radius: 0;
                    padding: 16px; margin-bottom: 12px; border-left: 3px solid rgba(90,174,232,0.3);
                    overflow: hidden;
                }
                .fc-result-section h4 { font-size: 1.15em; text-transform: uppercase; letter-spacing: 1px; color: #5aaee8; margin-bottom: 10px; }
                .fc-buff-list { display: flex; flex-direction: column; gap: 6px; }
                .fc-buff { display: flex; align-items: flex-start; gap: 8px; font-size: 0.9em; color: #ccc; line-height: 1.4; overflow-wrap: anywhere; word-break: break-word; }
                .fc-buff span { min-width: 0; }
                .fc-buff-icon { flex-shrink: 0; width: 18px; text-align: center; }
                .fc-buff-good { color: #2ecc71; } .fc-buff-warn { color: #f1c40f; }
                .fc-buff-bad { color: #e74c3c; } .fc-buff-info { color: #3498db; }
                .fc-empty-result { color: #555; font-style: italic; font-size: 0.9em; padding: 20px; text-align: center; }
                .fc-faction-bar { display: flex; gap: 6px; flex-wrap: wrap; margin-bottom: 10px; }
                .fc-faction-pill { padding: 4px 12px; border-radius: 20px; font-size: 0.8em; font-weight: 700; display: inline-flex; align-items: center; gap: 4px; }
                .fc-pill-br { background: rgba(90,174,232,0.15); color: #5aaee8; border: 1px solid rgba(90,174,232,0.3); }
                .fc-pill-wod { background: rgba(52,152,219,0.15); color: #3498db; border: 1px solid rgba(52,152,219,0.3); }
                .fc-pill-goo { background: rgba(46,204,113,0.15); color: #cca22e; border: 1px solid rgba(46,204,113,0.3); }
                .fc-picker-overlay {
                    display: none; position: fixed; top: 0; left: 0; right: 0; bottom: 0;
                    background: rgba(0,0,0,0.75); z-index: 2000;
                    align-items: flex-end; justify-content: center; padding: 0;
                }
                .fc-picker-overlay.open { display: flex; }
                .fc-picker {
                    background: rgba(26, 26, 46, 0.99); border-radius: 18px 18px 0 0;
                    width: 100%; max-width: 600px; max-height: 85vh;
                    overflow: hidden; display: flex; flex-direction: column;
                    border: 1px solid rgba(90,174,232,0.2); border-bottom: none;
                    animation: fc-slide-up 0.3s ease;
                }
                @keyframes fc-slide-up { from { transform: translateY(100%); } to { transform: translateY(0); } }
                .fc-picker-head {
                    padding: 16px 20px; border-bottom: 1px solid rgba(255,255,255,0.06);
                    display: flex; align-items: center; justify-content: space-between; flex-shrink: 0;
                }
                .fc-picker-head h3 { margin: 0; font-size: 1em; color: #fff; }
                .fc-picker-head h3::before { content: none; }
                .fc-picker-close {
                    background: rgba(255,255,255,0.06); border: none; color: #999;
                    width: 32px; height: 32px; border-radius: 50%; cursor: pointer;
                    font-size: 1.1em; display: flex; align-items: center; justify-content: center;
                }
                .fc-picker-close:hover { background: rgba(255,255,255,0.12); color: #fff; }
                .fc-picker-filters {
                    padding: 12px 20px; border-bottom: 1px solid rgba(255,255,255,0.06);
                    display: flex; gap: 6px; flex-wrap: wrap; flex-shrink: 0;
                }
                .fc-filter-btn {
                    padding: 6px 14px; border-radius: 20px; font-size: 0.78em; font-weight: 600;
                    border: 1px solid rgba(255,255,255,0.12); background: rgba(255,255,255,0.04);
                    color: #999; cursor: pointer; transition: all 0.2s;
                }
                .fc-filter-btn:hover { border-color: rgba(90,174,232,0.3); color: #ccc; }
                .fc-filter-btn.active { background: rgba(90,174,232,0.15); color: #5aaee8; border-color: rgba(90,174,232,0.4); }
                .fc-picker-list { overflow-y: auto; padding: 8px 12px; flex: 1; -webkit-overflow-scrolling: touch; }
                .fc-hero-option {
                    display: flex; align-items: center; gap: 12px;
                    padding: 10px 12px; border-radius: 0; cursor: pointer;
                    transition: background 0.15s; border-bottom: 1px solid rgba(255,255,255,0.03);
                }
                .fc-hero-option:hover { background: rgba(90,174,232,0.08); }
                .fc-hero-option.disabled { opacity: 0.3; pointer-events: none; }
                .fc-ho-icon {
                    width: 36px; height: 36px; border-radius: 0;
                    display: flex; align-items: center; justify-content: center;
                    font-size: 1em; font-weight: 800; flex-shrink: 0;
                }
                .fc-ho-info { flex: 1; min-width: 0; }
                .fc-ho-name { font-weight: 700; font-size: 0.88em; color: #fff; }
                .fc-ho-detail { font-size: 0.75em; color: #888; margin-top: 2px; }
                .fc-ho-tier { font-size: 0.72em; font-weight: 700; padding: 2px 8px; border-radius: 0; flex-shrink: 0; }
                .fc-ho-badges { display: flex; gap: 4px; flex-shrink: 0; align-items: center; }
                .fc-badge-rarity {
                    font-size: 0.68em; font-weight: 800; padding: 2px 7px; border-radius: 0;
                    line-height: 1.2; letter-spacing: 0.5px;
                }
                .fc-badge-power {
                    font-size: 0.65em; font-weight: 700; padding: 2px 6px; border-radius: 0;
                    line-height: 1.2; border: 1px solid;
                }
                .fc-rarity-s { background: rgba(255,165,0,0.2); color: #ffa500; }
                .fc-rarity-a { background: rgba(155,89,182,0.2); color: #9b59b6; }
                .fc-rarity-b { background: rgba(100,149,237,0.2); color: #6495ed; }
                .fc-power-splus { background: rgba(46,204,113,0.12); color: #95a5a6; border-color: rgba(149,165,166,0.3); }
                .fc-power-s { background: rgba(52,152,219,0.12); color: #95a5a6; border-color: rgba(149,165,166,0.3); }
                .fc-power-aplus { background: rgba(155,89,182,0.1); color: #95a5a6; border-color: rgba(149,165,166,0.3); }
                .fc-power-a { background: rgba(241,196,15,0.1); color: #95a5a6; border-color: rgba(149,165,166,0.3); }
                .fc-power-bplus { background: rgba(230,126,34,0.1); color: #95a5a6; border-color: rgba(149,165,166,0.3); }
                .fc-power-b { background: rgba(149,165,166,0.1); color: #95a5a6; border-color: rgba(149,165,166,0.3); }
                .fc-power-c { background: rgba(231,76,60,0.1); color: #95a5a6; border-color: rgba(149,165,166,0.3); }
                .fc-tier-s { background: rgba(255,165,0,0.15); color: #ffa500; }
                .fc-tier-a { background: rgba(155,89,182,0.15); color: #9b59b6; }
                .fc-tier-b { background: rgba(100,149,237,0.15); color: #6495ed; }
                @media (max-width: 600px) {
                    .fc-slots { grid-template-columns: 1fr; }
                    .fc-back-row { grid-template-columns: 1fr; }
                    .fc-slot { padding: 10px 8px; min-height: 56px; gap: 8px; }
                    .fc-slot-icon { width: 28px; height: 28px; font-size: 0.9em; }
                    .fc-slot-hero-img { width: 32px; height: 32px; }
                    .fc-slot-icons { gap: 4px; }
                    .fc-ho-hero-img { width: 28px; height: 28px; }
                    .fc-slot-name { font-size:1em; }
                    .fc-picker { max-width: 100%; border-radius: 16px 16px 0 0; }
                    .fc-form-body { padding: 12px; overflow: hidden; }
                    .fc-result-section { padding: 12px; }
                    .fc-grade-banner { padding: 12px; gap: 10px; flex-wrap: wrap; }
                    .fc-grade-letter { width: 40px; height: 40px; font-size: 1.2em; }
                    .fc-grade-desc { word-break: break-word; }
                    .fc-buff { font-size: 0.9em; word-break: break-word; overflow-wrap: anywhere; }
                    .fc-buff span { min-width: 0; }
                    .fc-synergy-highlight { padding: 8px 10px; }
                    .fc-buff-stacked { margin-left: 8px; padding-left: 8px; }
                    .fc-preset-btn { padding: 6px 10px; font-size: 0.9em; }
                    .fc-presets h4 { font-size: 1.15em; }
                    .fc-faction-pill { font-size: 0.8em; padding: 3px 8px; }
                }
                @media (max-width: 420px) {
                    .fc-form-body { padding: 10px; }
                    .fc-result-section { padding: 10px; }
                    .fc-grade-banner { padding: 10px; gap: 8px; }
                    .fc-grade-letter { width: 36px; height: 36px; font-size: 1.1em; }
                    .fc-grade-title { font-size: 1.2em; }
                    .fc-grade-desc { font-size: 0.85em; }
                    .fc-buff { font-size: 0.78em; gap: 5px; }
                    .fc-slot-meta { font-size: 0.7em; }
                    .fc-preset-btn { padding: 5px 8px; font-size: 0.82em; }
                    .fc-preset-grid { gap: 5px; }
                }
            
        /* ---- ADVANCED GUIDE BLOCKS ---- */
        .advanced-block {
            margin: 18px 0;
            border: 1px solid rgba(241, 196, 15, 0.22);
            border-radius: 0;
            overflow: hidden;
            background: rgba(241, 196, 15, 0.06);
        }
        .advanced-block summary {
            list-style: none;
            cursor: pointer;
            padding: 14px 18px;
            font-weight: 700;
            color: #f1c40f;
            display: flex;
            align-items: center;
            justify-content: space-between;
            gap: 12px;
            user-select: none;
        }
        .advanced-block summary::-webkit-details-marker { display: none; }
        .advanced-block summary::after {
            content: '▾';
            color: #f1c40f;
            font-size: 1.15em;
            transition: transform 0.2s ease;
        }
        .advanced-block[open] summary::after { transform: rotate(180deg); }
        .advanced-block .advanced-content {
            padding: 0 18px 18px;
            color: #d9d9d9;
            border-top: 1px solid rgba(255,255,255,0.06);
            background: rgba(0,0,0,0.08);
        }
        .theme-tag.advanced {
            background: rgba(241,196,15,0.18);
            color: #f1c40f;
            border-color: rgba(241,196,15,0.28);
        }
        .scenario-grid {
            display: grid;
            grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
            gap: 16px;
            margin: 20px 0;
        }
        .scenario-card h4 {
            margin: 0 0 10px;
            color: #fff;
            font-size: 1.05em;
        }
        .scenario-card .label {
            display: inline-block;
            font-size: 0.75em;
            font-weight: 700;
            text-transform: uppercase;
            letter-spacing: 0.8px;
            margin-bottom: 10px;
            color: #f1c40f;
        }
        .mini-divider {
            height: 1px;
            background: rgba(255,255,255,0.08);
            margin: 14px 0;
        }

        /* SEASON 2 META */

            .s2m-hero{background:linear-gradient(135deg,rgba(10,20,50,0.95) 0%,rgba(5,30,60,0.9) 50%,rgba(0,15,40,0.95) 100%);border:1px solid rgba(78,175,205,0.2);border-radius:16px;padding:28px 32px 24px;margin-bottom:32px;position:relative;overflow:hidden;}
            .s2m-hero::before{content:\'\';position:absolute;inset:0;background:radial-gradient(ellipse at 80% 50%,rgba(78,175,205,0.08) 0%,transparent 65%);pointer-events:none;}
            .s2m-hero h2{margin:0 0 8px;font-size:1.6em;color:#fff;}
            .s2m-hero p{margin:0;color:rgba(255,255,255,0.65);font-size:0.95em;line-height:1.6;}
            .s2m-badge{display:inline-block;background:rgba(78,175,205,0.18);color:#4eafcd;font-size:0.7em;font-weight:700;letter-spacing:1.2px;text-transform:uppercase;padding:3px 10px;border-radius:20px;border:1px solid rgba(78,175,205,0.3);margin-bottom:12px;}
            .s2m-nav{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:28px;}
            .s2m-nav-btn{padding:8px 18px;border-radius:8px;border:1.5px solid rgba(255,255,255,0.1);background:rgba(255,255,255,0.04);color:#aaa;cursor:pointer;font-size:0.82em;font-weight:700;letter-spacing:0.5px;text-transform:uppercase;transition:all 0.2s;}
            .s2m-nav-btn:hover{background:rgba(78,175,205,0.12);border-color:rgba(78,175,205,0.4);color:#4eafcd;}
            .s2m-nav-btn.active{background:rgba(78,175,205,0.2);border-color:#4eafcd;color:#fff;}
            .s2m-panel{display:none;}.s2m-panel.active{display:block;}
            .s2m-checklist-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px;margin-bottom:24px;}
            .s2m-check-card{background:rgba(22,33,62,0.6);border-radius:14px;border:1.5px solid rgba(255,255,255,0.07);overflow:hidden;}
            .s2m-check-header{padding:12px 18px;font-weight:700;font-size:0.82em;text-transform:uppercase;letter-spacing:1px;display:flex;align-items:center;gap:8px;border-bottom:1px solid rgba(255,255,255,0.06);}
            .s2m-check-header.daily{background:rgba(78,175,205,0.12);color:#4eafcd;}
            .s2m-check-header.weekly{background:rgba(255,193,7,0.10);color:#ffc107;}
            .s2m-check-header.situational{background:rgba(90,174,232,0.10);color:#5aaee8;}
            .s2m-check-body{padding:14px 18px;}
            .s2m-check-item{display:flex;align-items:flex-start;gap:10px;padding:7px 0;border-bottom:1px solid rgba(255,255,255,0.04);font-size:0.88em;line-height:1.45;color:rgba(255,255,255,0.82);cursor:pointer;user-select:none;}
            .s2m-check-item:last-child{border-bottom:none;}
            .s2m-check-box{width:16px;height:16px;flex-shrink:0;border-radius:4px;border:1.5px solid rgba(255,255,255,0.2);margin-top:1px;display:flex;align-items:center;justify-content:center;transition:all 0.18s;background:transparent;}
            .s2m-check-item.done .s2m-check-box{background:#4eafcd;border-color:#4eafcd;}
            .s2m-check-item.done .s2m-check-box::after{content:"✓";font-size:0.7em;color:#fff;font-weight:900;}
            .s2m-check-item.done .s2m-check-text{opacity:0.4;text-decoration:line-through;}
            .s2m-check-text{flex:1;}
            .s2m-check-priority{font-size:0.62em;font-weight:800;padding:1px 6px;border-radius:4px;text-transform:uppercase;letter-spacing:0.8px;flex-shrink:0;margin-top:2px;}
            .s2m-check-priority.must{background:rgba(90,174,232,0.2);color:#5aaee8;}
            .s2m-check-priority.high{background:rgba(255,193,7,0.15);color:#ffc107;}
            .s2m-check-priority.opt{background:rgba(255,255,255,0.07);color:#888;}
            .s2m-reset-btn{font-size:0.75em;padding:6px 14px;border-radius:7px;border:1px solid rgba(255,255,255,0.12);background:rgba(255,255,255,0.04);color:#888;cursor:pointer;transition:all 0.2s;margin-top:4px;}
            .s2m-reset-btn:hover{background:rgba(90,174,232,0.15);color:#5aaee8;border-color:rgba(90,174,232,0.3);}
            .s2m-progress-bar{height:6px;border-radius:4px;background:rgba(255,255,255,0.07);overflow:hidden;margin-bottom:20px;}
            .s2m-progress-fill{height:100%;border-radius:4px;background:linear-gradient(90deg,#4eafcd,#2dd4bf);transition:width 0.3s ease;}
            .s2m-progress-label{font-size:0.78em;color:#888;margin-bottom:8px;display:flex;justify-content:space-between;}
            .s2m-phase-timeline{display:flex;gap:0;margin-bottom:28px;border-radius:12px;overflow:hidden;border:1px solid rgba(255,255,255,0.07);}
            .s2m-phase{flex:1;padding:16px 14px;text-align:center;background:rgba(22,33,62,0.5);border-right:1px solid rgba(255,255,255,0.07);transition:background 0.2s;}
            .s2m-phase:last-child{border-right:none;}
            .s2m-phase-icon{font-size:1.4em;margin-bottom:6px;}
            .s2m-phase-time{font-size:0.65em;font-weight:700;color:#888;text-transform:uppercase;letter-spacing:0.8px;margin-bottom:4px;}
            .s2m-phase-name{font-size:0.82em;font-weight:700;color:#fff;margin-bottom:4px;}
            .s2m-phase-desc{font-size:0.7em;color:rgba(255,255,255,0.5);line-height:1.4;}
            .s2m-phase.prep{border-top:3px solid #4eafcd;}
            .s2m-phase.march{border-top:3px solid #ffc107;}
            .s2m-phase.assault{border-top:3px solid #5aaee8;}
            .s2m-phase.hold{border-top:3px solid #a78bfa;}
            @media(max-width:640px){.s2m-phase-timeline{flex-direction:column;}.s2m-phase{border-right:none;border-bottom:1px solid rgba(255,255,255,0.07);}.s2m-phase:last-child{border-bottom:none;}}
            .s2m-hive-diagram{background:rgba(10,20,45,0.8);border:1.5px solid rgba(78,175,205,0.2);border-radius:14px;padding:20px;margin-bottom:20px;}
            .s2m-hive-title{font-size:0.78em;font-weight:700;color:#4eafcd;text-transform:uppercase;letter-spacing:1px;margin-bottom:16px;}
            .s2m-hive-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:6px;max-width:340px;margin:0 auto 16px;}
            .s2m-hive-cell{aspect-ratio:1;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:0.62em;font-weight:700;text-align:center;line-height:1.2;padding:2px;border:1.5px solid rgba(255,255,255,0.08);}
            .s2m-hive-cell.ac{background:rgba(90,174,232,0.3);border-color:rgba(90,174,232,0.6);color:#5aaee8;}
            .s2m-hive-cell.r5{background:rgba(255,193,7,0.2);border-color:rgba(255,193,7,0.5);color:#ffc107;}
            .s2m-hive-cell.main{background:rgba(78,175,205,0.15);border-color:rgba(78,175,205,0.35);color:#4eafcd;}
            .s2m-hive-cell.farm{background:rgba(255,255,255,0.04);border-color:rgba(255,255,255,0.08);color:#555;}
            .s2m-hive-legend{display:flex;gap:10px;flex-wrap:wrap;font-size:0.7em;}
            .s2m-hive-legend-item{display:flex;align-items:center;gap:5px;}
            .s2m-hive-dot{width:10px;height:10px;border-radius:3px;flex-shrink:0;}
            .s2m-pit-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:14px;margin-bottom:20px;}
            .s2m-pit-card{background:rgba(22,33,62,0.6);border-radius:12px;overflow:hidden;border:1.5px solid rgba(255,255,255,0.07);}
            .s2m-pit-header{padding:10px 16px;font-weight:700;font-size:0.85em;display:flex;align-items:center;justify-content:space-between;}
            .s2m-pit-header.l1{background:rgba(78,175,205,0.15);color:#4eafcd;border-bottom:1px solid rgba(78,175,205,0.2);}
            .s2m-pit-header.l2{background:rgba(255,193,7,0.12);color:#ffc107;border-bottom:1px solid rgba(255,193,7,0.2);}
            .s2m-pit-header.l3{background:rgba(90,174,232,0.15);color:#5aaee8;border-bottom:1px solid rgba(90,174,232,0.2);}
            .s2m-pit-body{padding:14px 16px;}
            .s2m-pit-row{display:flex;justify-content:space-between;align-items:baseline;padding:4px 0;font-size:0.83em;border-bottom:1px solid rgba(255,255,255,0.04);}
            .s2m-pit-row:last-child{border-bottom:none;}
            .s2m-pit-label{color:#888;}
            .s2m-pit-value{font-weight:700;color:#fff;text-align:right;}
            .s2m-verdict{display:inline-flex;align-items:center;gap:4px;font-size:0.75em;font-weight:700;padding:2px 8px;border-radius:6px;}
            .s2m-verdict.go{background:rgba(78,175,205,0.15);color:#4eafcd;}
            .s2m-verdict.skip{background:rgba(90,174,232,0.15);color:#5aaee8;}
            .s2m-verdict.situational{background:rgba(255,193,7,0.12);color:#ffc107;}
            .s2m-two-col{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:20px;}
            @media(max-width:600px){.s2m-two-col{grid-template-columns:1fr;}}
            .s2m-stat-box{background:rgba(22,33,62,0.6);border:1.5px solid rgba(255,255,255,0.07);border-radius:12px;padding:16px 20px;}
            .s2m-stat-label{font-size:0.72em;color:#888;text-transform:uppercase;letter-spacing:0.8px;margin-bottom:4px;}

            /* CHAMPIONSHIP TAB */

                .cc-wrap { display:grid; grid-template-columns:1fr 1fr; gap:24px; margin-bottom:24px; }
                @media(max-width:820px){ .cc-wrap { grid-template-columns:1fr; } }
                .cc-side { background:rgba(22,33,62,0.6); border-radius:14px; border:2px solid rgba(255,255,255,0.06); overflow:hidden; }
                .cc-side-header { padding:14px 20px; font-weight:700; font-size:1.1em; text-transform:uppercase; letter-spacing:1px; border-bottom:1px solid rgba(255,255,255,0.06); display:flex; align-items:center; gap:10px; }
                .cc-side.cc-mine .cc-side-header { background:rgba(78,205,196,0.12); color:#4eafcd; }
                .cc-side.cc-enemy .cc-side-header { background:rgba(90,174,232,0.12); color:#5aaee8; }
                .cc-side-body { padding:16px; }

                .cc-form-block {
                    margin-bottom:12px; position:relative;
                    border:2px solid rgba(255,255,255,0.06); border-radius:12px; overflow:hidden;
                    transition:border-color 0.2s, box-shadow 0.2s, opacity 0.2s, transform 0.15s;
                    background:rgba(22,33,62,0.4);
                }
                .cc-form-block:last-child { margin-bottom:0; }
                .cc-form-block.cc-drag-over { border-color:rgba(90,174,232,0.5); box-shadow:0 0 16px rgba(90,174,232,0.15); }
                .cc-form-block.cc-dragging { opacity:0.4; transform:scale(0.97); }

                .cc-form-header {
                    display:flex; align-items:center; justify-content:space-between;
                    padding:10px 14px; background:rgba(255,255,255,0.03);
                    border-bottom:1px solid rgba(255,255,255,0.05); gap:8px;
                }
                .cc-form-header-left { display:flex; align-items:center; gap:10px; }
                .cc-drag-handle {
                    cursor:grab; font-size:1.1em; color:rgba(255,255,255,0.25);
                    padding:2px 4px; transition:color 0.2s; user-select:none; line-height:1;
                }
                .cc-drag-handle:hover { color:rgba(255,255,255,0.6); }
                .cc-drag-handle:active { cursor:grabbing; }
                .cc-form-label { font-size:0.85em; font-weight:700; text-transform:uppercase; letter-spacing:1.2px; color:#aaa; }
                .cc-form-header .cc-power-tag { font-size:0.8em; padding:2px 8px; border-radius:6px; background:rgba(255,255,255,0.06); color:#ccc; font-weight:600; }
                .cc-swap-btns { display:flex; gap:4px; }
                .cc-swap-btn {
                    width:26px; height:26px; border-radius:6px; border:1px solid rgba(255,255,255,0.1);
                    background:rgba(255,255,255,0.04); color:#888; cursor:pointer; font-size:0.75em;
                    display:flex; align-items:center; justify-content:center; transition:all 0.2s;
                }
                .cc-swap-btn:hover { background:rgba(90,174,232,0.15); border-color:rgba(90,174,232,0.3); color:#fff; }
                .cc-swap-btn.cc-disabled { opacity:0.2; pointer-events:none; }

                .cc-form-body { padding:12px 14px; }

                .cc-slots-grid { display:grid; grid-template-columns:repeat(5,1fr); gap:6px; }
                @media(max-width:480px){ .cc-slots-grid { gap:4px; } }
                .cc-slot {
                    aspect-ratio:1; border-radius:10px; cursor:pointer; position:relative;
                    display:flex; align-items:center; justify-content:center; flex-direction:column;
                    border:2px solid rgba(255,255,255,0.1); transition:all 0.2s; user-select:none;
                    background:rgba(255,255,255,0.03); min-width:0;
                }
                .cc-slot:hover { border-color:rgba(255,255,255,0.25); background:rgba(255,255,255,0.06); }
                .cc-slot.cc-br { border-color:rgba(220,50,50,0.5); background:rgba(220,50,50,0.1); text-align: center;}
                .cc-slot.cc-wd { border-color:rgba(78,205,196,0.5); background:rgba(78,205,196,0.1); text-align: center; }
                .cc-slot.cc-go { border-color:rgba(255,193,7,0.5); background:rgba(255,193,7,0.1); text-align: center; }
                .cc-slot .cc-slot-icon { width:28px; height:28px; object-fit:contain; }
                .cc-slot .cc-slot-icon-empty { font-size:1.4em; line-height:1; color:rgba(255,255,255,0.15); }
                .cc-slot .cc-slot-label { font-size:0.5em; font-weight:700; text-transform:uppercase; letter-spacing:0.5px; margin-top:2px; opacity:0.7; }
                @media(max-width:480px){ .cc-slot .cc-slot-icon { width:22px; height:22px; } .cc-slot .cc-slot-label { font-size:0.45em; } }

                .cc-power-row { margin-top:10px; display:flex; align-items:center; gap:8px; flex-wrap:wrap; }
                .cc-power-row label { font-size:0.8em; color:#888; white-space:nowrap; }
                .cc-power-row input {
                    flex:1; background:rgba(255,255,255,0.06); border:1px solid rgba(255,255,255,0.12);
                    border-radius:8px; padding:5px 12px; color:#fff; font-size:0.95em; font-weight:600;
                    outline:none; transition:border-color 0.2s; min-width:80px;
                }
                .cc-power-row input:focus { border-color:#5aaee8; }
                .cc-power-row input::placeholder { color:rgba(255,255,255,0.25); }
                .cc-unit-toggle {
                    display:flex; border-radius:6px; overflow:hidden; border:1px solid rgba(255,255,255,0.12); flex-shrink:0;
                }
                .cc-unit-btn {
                    padding:6px 10px; font-size:0.7em; font-weight:700; cursor:pointer;
                    background:rgba(255,255,255,0.04); color:#888; border:none; transition:all 0.2s;
                    letter-spacing:0.3px;
                }
                .cc-unit-btn.active { background:rgba(90,174,232,0.25); color:#fff; }
                .cc-unit-btn:hover:not(.active) { background:rgba(255,255,255,0.08); color:#ccc; }

                .cc-faction-summary { margin-top:8px; display:flex; gap:8px; flex-wrap:wrap; }
                .cc-faction-pill {
                    font-size:0.7em; padding:2px 8px; border-radius:6px; font-weight:700;
                    letter-spacing:0.5px; display:flex; align-items:center; gap:4px;
                }
                .cc-faction-pill img { width:14px; height:14px; object-fit:contain; }
                .cc-faction-pill.cc-br-pill { background:rgba(220,50,50,0.15); color:#e05555; }
                .cc-faction-pill.cc-wd-pill { background:rgba(78,205,196,0.15); color:#4eafcd; }
                .cc-faction-pill.cc-go-pill { background:rgba(255,193,7,0.15); color:#ffc107; }
                .cc-faction-pill.cc-empty-pill { background:rgba(255,255,255,0.06); color:#666; }

                .cc-results { margin-top:0; }
                .cc-run-btn {
                    display:block; width:100%; padding:14px; border:none; border-radius:12px;
                    background:linear-gradient(135deg,#5aaee8,#3e86bd); color:#fff; font-size:1.05em;
                    font-weight:700; text-transform:uppercase; letter-spacing:1.5px; cursor:pointer;
                    transition:all 0.25s; margin-bottom:20px;
                }
                .cc-run-btn:hover { transform:translateY(-1px); box-shadow:0 6px 20px rgba(90,174,232,0.4); }
                .cc-run-btn:active { transform:translateY(0); }

                .cc-result-card {
                    background:rgba(22,33,62,0.6); border-radius:14px; border:2px solid rgba(255,255,255,0.06);
                    overflow:hidden; margin-bottom:16px;
                }
                .cc-result-header {
                    padding:14px 20px; display:flex; align-items:center; justify-content:space-between;
                    border-bottom:1px solid rgba(255,255,255,0.06);
                }
                .cc-result-header h3 { margin:0; font-size:1em; color:#fff; }
                .cc-result-header h3::before { content:none; }

                .cc-result-body { padding:16px 20px; }

                /* Matchup rows - mobile-friendly stacked layout */
                .cc-matchup-row {
                    display:grid; grid-template-columns:1fr auto 1fr auto; gap:8px;
                    align-items:center; padding:10px 0;
                    border-bottom:1px solid rgba(255,255,255,0.04); font-size:0.9em;
                    align-items: flex-start;
                }
                .cc-matchup-row:last-child { border-bottom:none; }
                .cc-matchup-vs { color:#888; font-weight:600; font-size:0.85em; text-align:center; }
                .cc-matchup-form { display:flex; flex-direction: column; align-items:flex-start; gap:5px; min-width:0; }
                .cc-matchup-form.cc-right { justify-content:flex-end; align-items: flex-end; }
                .cc-matchup-result {
                    font-weight:700; font-size:0.8em; padding:2px 8px; border-radius:6px; white-space:nowrap; text-align:center;
                }
                .cc-matchup-result.cc-w { color:#4eafcd; background:rgba(78,205,196,0.1); }
                .cc-matchup-result.cc-l { color:#5aaee8; background:rgba(90,174,232,0.1); }
                .cc-matchup-pow { font-size:0.7em; color:#888; white-space:nowrap; }
                .cc-matchup-counter { font-size:0.65em; white-space:nowrap; }
                @media(max-width:600px){
                    .cc-matchup-row { grid-template-columns:1fr auto 1fr auto; gap:4px; font-size:0.8em; padding:8px 0; }
                    .cc-matchup-form { gap:3px; }
                    .cc-matchup-result { padding:2px 6px; font-size:0.75em; }
                    .cc-matchup-pow { font-size:0.65em; }
                    .cc-result-body { padding:12px; }
                    .cc-mini-slot { width:14px; height:14px; border-radius:3px; }
                    .cc-mini-slot img { width:11px; height:11px; }
                }

                .cc-mini-slot {
                    width:18px; height:18px; border-radius:4px; display:inline-flex; align-items:center;
                    justify-content:center; flex-shrink:0; overflow:hidden;
                }
                .cc-mini-slot img { width:14px; height:14px; object-fit:contain; }
                .cc-mini-slot.cc-br { background:rgba(220,50,50,0.2); }
                .cc-mini-slot.cc-wd { background:rgba(78,205,196,0.2); }
                .cc-mini-slot.cc-go { background:rgba(255,193,7,0.2); }
                .cc-mini-slot.cc-none { background:rgba(255,255,255,0.06); color:#555; }
                .cc-form-name { font-weight:600; font-size:0.85em; white-space:nowrap; }

                .cc-summary-box {
                    background:rgba(22,33,62,0.8); border-radius:14px; border:2px solid rgba(78,205,196,0.2);
                    padding:20px; margin-bottom:20px;
                }
                .cc-summary-title { font-size:1.1em; font-weight:700; color:#4eafcd; margin-bottom:12px; text-transform:uppercase; letter-spacing:1px; }
                .cc-summary-stat { display:flex; justify-content:space-between; padding:6px 0; border-bottom:1px solid rgba(255,255,255,0.04); font-size:0.95em; }
                .cc-summary-stat:last-child { border-bottom:none; }
                .cc-summary-stat .cc-label { color:#aaa; }
                .cc-summary-stat .cc-value { font-weight:700; }

                .cc-best-box {
                    background:rgba(78,205,196,0.08); border:2px solid rgba(78,205,196,0.25);
                    border-radius:14px; padding:20px; margin-bottom:20px;
                }
                .cc-best-title { font-size:0.9em; font-weight:700; color:#4eafcd; margin-bottom:10px; text-transform:uppercase; letter-spacing:1px; }
                .cc-best-lineup { display:flex; gap:12px; flex-wrap:wrap; }
                .cc-best-item {
                    background:rgba(255,255,255,0.04); border-radius:10px; padding:10px 14px;
                    flex:1; min-width:100px; text-align:center;
                }
                .cc-best-item .cc-bi-label { font-size:0.7em; color:#888; text-transform:uppercase; letter-spacing:1px; margin-bottom:4px; }
                .cc-best-item .cc-bi-factions { display:flex; justify-content:center; gap:4px; margin-top:6px; }

                .cc-perm-table { width:100%; border-collapse:collapse; font-size:0.85em; }
                .cc-perm-table th { text-align:left; padding:8px 10px; color:#888; font-weight:600; border-bottom:2px solid rgba(255,255,255,0.08); font-size:0.85em; text-transform:uppercase; letter-spacing:0.5px; }
                .cc-perm-table td { padding:8px 10px; border-bottom:1px solid rgba(255,255,255,0.04); }
                .cc-perm-highlight { background:rgba(78,205,196,0.06) !important; }
                .cc-perm-highlight td { color:#fff !important; }
                @media(max-width:600px){
                    .cc-perm-table { font-size:0.78em; }
                    .cc-perm-table th, .cc-perm-table td { padding:6px 6px; }
                }

                .cc-info-note {
                    background:rgba(255,193,7,0.08); border:2px solid rgba(255,193,7,0.2);
                    border-radius:10px; padding:14px 18px; margin-bottom:20px;
                    font-size:0.95em; color:rgba(255,255,255,0.7); line-height:1.6;
                }
                .cc-info-note strong { color:#ffc107; }

                .cc-counter-ref {
                    position:relative; width:min(100%, 360px); height:250px; margin:18px auto 22px;
                }
                .cc-counter-center {
                    position:absolute; top:57%; left:50%; transform:translate(-50%, -50%);
                    width:48px; height:48px; border-radius:50%; display:flex; align-items:center; justify-content:center;
                    font-size:1.35em; font-weight:900; color:rgba(255,255,255,0.18);
                    background:radial-gradient(circle, rgba(255,255,255,0.06) 0%, rgba(255,255,255,0.02) 72%, rgba(255,255,255,0) 100%);
                    border:1px solid rgba(255,255,255,0.06);
                    pointer-events:none;
                }
                .cc-counter-node {
                    position:absolute; width:119px; min-height:108px; border-radius:20px;
                    border:2px solid rgba(255,255,255,0.08); box-shadow:0 10px 28px rgba(0,0,0,0.22);
                    display:flex; flex-direction:column; align-items:center; justify-content:center;
                    gap:8px; padding:12px 10px; text-align:center;
                }
                .cc-counter-node img { width:52px; height:52px; object-fit:contain; }
                .cc-counter-top { top:0; left:50%; transform:translateX(-50%); }
                .cc-counter-left { left:16px; bottom:6px; }
                .cc-counter-right { right:16px; bottom:6px; }
                .cc-counter-name { font-size:0.76em; font-weight:800; line-height:1.15; }
                .cc-counter-hint { font-size:0.62em; font-weight:700; color:rgba(255,255,255,0.5); text-transform:uppercase; letter-spacing:0.8px; }
                .cc-counter-node.br { border-color:rgba(224,85,85,0.45); }
                .cc-counter-node.wd { border-color:rgba(78,175,205,0.45); }
                .cc-counter-node.go { border-color:rgba(255,193,7,0.45); }
                .cc-counter-node.br .cc-counter-name { color:#e05555; }
                .cc-counter-node.wd .cc-counter-name { color:#4eafcd; }
                .cc-counter-node.go .cc-counter-name { color:#ffc107; }
                .cc-counter-arrow {
                    position:absolute; width:53px; height:0; border-top:2px solid #888;
                }
                .cc-counter-arrow::after {
                    content:''; position:absolute; right:-5px; top:-7px; width:0; height:0;
                    border-top:6px solid transparent; border-bottom:6px solid transparent; border-left:13px solid #888;
                }
                .cc-counter-arrow.a1 { top:99px; left:241px; transform:rotate(231deg); }
                .cc-counter-arrow.a2 { top:196px; left:156px; transform:rotate(0deg); }
                .cc-counter-arrow.a3 { top:101px; left:61px; transform:rotate(129deg); }
                @media(max-width:600px){
                    .cc-counter-ref { width:min(100%, 320px); height:230px; }
                    .cc-counter-node { width:107px; min-height:96px; border-radius:18px; padding:10px 8px; }
                    .cc-counter-node img { width:46px; height:46px; }
                    .cc-counter-name { font-size:0.72em; }
                    .cc-counter-top { top:2px; }
                    .cc-counter-left { left:15px; bottom:10px; }
                    .cc-counter-right { right:15px; bottom:10px; }
                    .cc-counter-arrow { width:53px; }
                    .cc-counter-arrow.a1 { top:92px; left:213px; transform:rotate(231deg); }
                    .cc-counter-arrow.a2 { top:171px; left:134px; transform:rotate(0deg); }
                    .cc-counter-arrow.a3 { top:94px; left:49px; transform:rotate(129deg); }
                }

                .cc-autofill-row { display:flex; gap:6px; flex-wrap:wrap; margin-bottom:10px; }
                .cc-autofill-btn {
                    font-size:0.7em; padding:4px 10px; border-radius:6px; border:1px solid rgba(255,255,255,0.12);
                    background:rgba(255,255,255,0.04); color:#ccc; cursor:pointer; transition:all 0.2s;
                    font-weight:600; letter-spacing:0.3px; display:flex; align-items:center; gap:4px;
                }
                .cc-autofill-btn img { width:14px; height:14px; object-fit:contain; }
                .cc-autofill-btn:hover { background:rgba(90,174,232,0.15); border-color:rgba(90,174,232,0.3); color:#fff; }

                .cc-series-block { margin-bottom:14px; padding:12px; background:rgba(255,255,255,0.02); border-radius:10px; }
                .cc-series-header { display:flex; justify-content:space-between; align-items:center; margin-bottom:8px; flex-wrap:wrap; gap:6px; }
                @media(max-width:600px){
                    .cc-best-lineup { gap:8px; }
                    .cc-best-item { padding:8px 10px; min-width:80px; }
                    .cc-summary-stat { font-size:0.85em; }
                }