﻿/* CSS: ใส่ใน <style> */
/* SERVICE HUB FILTER PRO MAX */
        .cit-service-hub{
            position:relative;
            padding:76px 0 82px;
            overflow:hidden;
            background:
                radial-gradient(circle at 10% 10%,rgba(72,199,255,.28),transparent 27%),
                radial-gradient(circle at 88% 18%,rgba(255,255,255,.18),transparent 28%),
                linear-gradient(135deg,#061f4d 0%,#0b3f85 48%,#0f75c9 100%);
            color:#fff;
        }
        .cit-service-hub:before{
            content:'';
            position:absolute;
            inset:0;
            pointer-events:none;
            background-image:
                linear-gradient(rgba(255,255,255,.055) 1px,transparent 1px),
                linear-gradient(90deg,rgba(255,255,255,.055) 1px,transparent 1px);
            background-size:50px 50px;
            opacity:.20;
        }
        .cit-service-hub:after{
            content:'';
            position:absolute;
            right:-210px;
            top:-170px;
            width:620px;
            height:620px;
            border-radius:999px;
            pointer-events:none;
            background:radial-gradient(circle,rgba(72,199,255,.30),rgba(35,135,232,.08) 58%,transparent 73%);
        }
        .sv-wrap{position:relative;z-index:1;}
        .sv-head{
            display:flex;
            align-items:flex-end;
            justify-content:space-between;
            gap:24px;
            margin-bottom:24px;
        }
        .sv-kicker{
            display:inline-flex;
            align-items:center;
            gap:9px;
            margin-bottom:13px;
            padding:9px 15px;
            border-radius:999px;
            background:rgba(255,255,255,.13);
            border:1px solid rgba(255,255,255,.22);
            color:#fff;
            font-size:13px;
            font-weight:950;
            letter-spacing:.7px;
            box-shadow:0 14px 34px rgba(0,0,0,.13);
        }
        .sv-title{
            margin:0;
            color:#fff;
            font-size:clamp(30px,4vw,52px);
            font-weight:950;
            line-height:1.14;
            letter-spacing:-.5px;
        }
        .sv-title span{
            background:linear-gradient(90deg,#ffffff,#8ee4ff);
            -webkit-background-clip:text;
            background-clip:text;
            color:transparent;
        }
        .sv-subtitle{
            max-width:870px;
            margin:12px 0 0;
            color:rgba(255,255,255,.84);
            font-size:16px;
            line-height:1.85;
        }
        .sv-counter{
            flex:0 0 auto;
            min-width:178px;
            padding:17px 18px;
            border-radius:24px;
            background:rgba(255,255,255,.13);
            border:1px solid rgba(255,255,255,.22);
            box-shadow:0 18px 44px rgba(3,22,55,.16);
            backdrop-filter:blur(12px);
            text-align:center;
        }
        .sv-counter strong{
            display:block;
            font-size:38px;
            line-height:1;
            font-weight:950;
            color:#fff;
        }
        .sv-counter span{
            display:block;
            margin-top:6px;
            color:rgba(255,255,255,.76);
            font-size:13px;
            font-weight:800;
        }
        .sv-toolbar{
            display:grid;
            grid-template-columns:minmax(220px,1fr) auto;
            gap:14px;
            align-items:center;
            margin-bottom:20px;
            padding:14px;
            border-radius:28px;
            background:rgba(255,255,255,.12);
            border:1px solid rgba(255,255,255,.20);
            box-shadow:0 18px 48px rgba(3,22,55,.14);
            backdrop-filter:blur(12px);
        }
        .sv-search{
            position:relative;
            min-width:0;
        }
        .sv-search i{
            position:absolute;
            left:18px;
            top:50%;
            transform:translateY(-50%);
            color:#0d63bf;
            font-size:16px;
            z-index:2;
        }
        .sv-search input{
            width:100%;
            min-height:52px;
            border:0;
            outline:0;
            border-radius:999px;
            padding:13px 18px 13px 46px;
            color:#123d76;
            background:rgba(255,255,255,.96);
            box-shadow:inset 0 1px 0 rgba(255,255,255,.92),0 12px 30px rgba(3,22,55,.10);
            font-family:'Noto Sans Thai Looped','Prompt','Sarabun',sans-serif;
            font-size:14px;
            font-weight:800;
        }
        .sv-search input::placeholder{color:#7d8ca3;}
        .sv-filters{
            display:flex;
            flex-wrap:wrap;
            gap:9px;
            justify-content:flex-end;
        }
        .sv-filter{
            display:inline-flex;
            align-items:center;
            justify-content:center;
            gap:8px;
            min-height:44px;
            padding:10px 15px;
            border-radius:999px;
            border:1px solid rgba(255,255,255,.22);
            background:rgba(255,255,255,.12);
            color:#fff;
            font-family:'Noto Sans Thai Looped','Prompt','Sarabun',sans-serif;
            font-size:13px;
            font-weight:950;
            cursor:pointer;
            transition:all .23s ease;
        }
        .sv-filter:hover{
            transform:translateY(-2px);
            background:rgba(255,255,255,.20);
        }
        .sv-filter.active{
            background:#fff;
            color:#0b4f9d;
            border-color:rgba(255,255,255,.82);
            box-shadow:0 14px 34px rgba(0,0,0,.14);
        }
        .sv-hint{
            display:flex;
            align-items:center;
            justify-content:space-between;
            gap:14px;
            margin-bottom:17px;
            color:rgba(255,255,255,.80);
            font-size:13px;
            font-weight:800;
        }
        .sv-hint span{
            display:inline-flex;
            align-items:center;
            gap:8px;
        }
        .sv-grid{
            display:grid;
            grid-template-columns:repeat(4,minmax(0,1fr));
            gap:15px;
        }
        .sv-card{
            position:relative;
            min-height:282px;
            display:flex;
            flex-direction:column;
            overflow:hidden;
            border-radius:26px;
            padding:18px;
            background:rgba(255,255,255,.96);
            color:#16345c;
            border:1px solid rgba(255,255,255,.75);
            box-shadow:0 22px 52px rgba(2,18,50,.20);
            transition:transform .24s ease,box-shadow .24s ease,border-color .24s ease,opacity .2s ease;
        }
        .sv-card:before{
            content:'';
            position:absolute;
            inset:0;
            pointer-events:none;
            background:
                radial-gradient(circle at 16% 8%,rgba(35,135,232,.15),transparent 32%),
                linear-gradient(135deg,rgba(35,135,232,.08),transparent 62%);
            opacity:.95;
        }
        .sv-card:hover{
            transform:translateY(-5px);
            border-color:rgba(72,199,255,.55);
            box-shadow:0 28px 66px rgba(2,18,50,.26);
        }
        .sv-card.is-hide{
            display:none;
        }
        .sv-card-top{
            position:relative;
            display:flex;
            align-items:flex-start;
            justify-content:space-between;
            gap:10px;
            margin-bottom:12px;
        }
        .sv-icon{
            width:58px;
            height:58px;
            flex:0 0 58px;
            display:inline-flex;
            align-items:center;
            justify-content:center;
            border-radius:21px;
            color:#0e66c2;
            font-size:27px;
            background:linear-gradient(135deg,#eaf5ff,#ffffff);
            box-shadow:inset 0 1px 0 rgba(255,255,255,.92),0 13px 28px rgba(9,47,103,.12);
        }
        .sv-card[data-type="private"] .sv-icon{
            color:#6734d8;
            background:linear-gradient(135deg,#f2edff,#ffffff);
        }
        .sv-card[data-type="security"] .sv-icon{
            color:#078a92;
            background:linear-gradient(135deg,#e8fbff,#ffffff);
        }
        .sv-badge{
            display:inline-flex;
            align-items:center;
            justify-content:center;
            padding:7px 10px;
            border-radius:999px;
            font-size:11px;
            line-height:1;
            font-weight:950;
            white-space:nowrap;
            color:#0d63bf;
            background:#ecf6ff;
            border:1px solid rgba(35,135,232,.17);
        }
        .sv-card[data-type="private"] .sv-badge{
            color:#6734d8;
            background:#f3efff;
            border-color:rgba(103,52,216,.18);
        }
        .sv-card[data-type="security"] .sv-badge{
            color:#078a92;
            background:#e9fbff;
            border-color:rgba(7,138,146,.18);
        }
        .sv-name{
            position:relative;
            margin:0;
            min-height:48px;
            color:#071f4a;
            font-size:17px;
            font-weight:950;
            line-height:1.42;
        }
        .sv-desc{
            position:relative;
            margin:8px 0 12px;
            min-height:45px;
            color:#687991;
            font-size:13px;
            line-height:1.7;
            font-weight:700;
        }
        .sv-groups{
            position:relative;
            display:flex;
            flex-wrap:wrap;
            gap:6px;
            margin:0 0 14px;
        }
        .sv-group-pill{
            display:inline-flex;
            align-items:center;
            gap:5px;
            padding:5px 8px;
            border-radius:999px;
            background:#f3f8ff;
            color:#0d63bf;
            border:1px solid rgba(35,135,232,.12);
            font-size:11px;
            font-weight:950;
            line-height:1;
        }
        .sv-group-pill.student{color:#0d63bf;background:#eef7ff;}
        .sv-group-pill.support{color:#078a92;background:#eaffff;}
        .sv-group-pill.academic{color:#158445;background:#ecfff4;}
        .sv-group-pill.executive{color:#b8770a;background:#fff6e8;}
        .sv-actions{
            position:relative;
            display:grid;
            grid-template-columns:1fr 1fr;
            gap:8px;
            margin-top:auto;
        }
        .sv-action{
            display:inline-flex;
            align-items:center;
            justify-content:center;
            gap:6px;
            min-height:38px;
            padding:8px 8px;
            border-radius:14px;
            font-size:12px;
            font-weight:950;
            text-decoration:none!important;
            transition:all .22s ease;
            white-space:nowrap;
        }
        .sv-action-primary{
            color:#fff!important;
            border:1px solid transparent;
            background:linear-gradient(135deg,#0d63bf,#1b9df0);
            box-shadow:0 11px 24px rgba(13,99,191,.22);
        }
        .sv-action-outline{
            color:#0d63bf!important;
            background:#fff;
            border:1px solid rgba(13,99,191,.28);
        }
        .sv-card[data-type="private"] .sv-action-primary{
            background:linear-gradient(135deg,#6434d8,#8e62ff);
            box-shadow:0 11px 24px rgba(100,52,216,.20);
        }
        .sv-card[data-type="private"] .sv-action-outline{
            color:#6434d8!important;
            border-color:rgba(100,52,216,.28);
        }
        .sv-action:hover{transform:translateY(-1px);filter:saturate(1.07);}
        .sv-empty{
            display:none;
            padding:28px;
            border-radius:28px;
            text-align:center;
            background:rgba(255,255,255,.94);
            color:#123d76;
            border:1px solid rgba(255,255,255,.80);
            box-shadow:0 22px 52px rgba(2,18,50,.16);
            font-weight:900;
        }
        .sv-empty.show{display:block;}
        .sv-system-note{
            display:grid;
            grid-template-columns:1.4fr repeat(3,1fr);
            gap:12px;
            margin-top:18px;
            padding:16px;
            border-radius:28px;
            background:rgba(255,255,255,.12);
            border:1px solid rgba(255,255,255,.20);
            box-shadow:0 18px 48px rgba(3,22,55,.14);
            backdrop-filter:blur(12px);
        }
        .sv-note-item{
            display:flex;
            align-items:center;
            gap:12px;
            color:#fff;
            min-height:62px;
        }
        .sv-note-item i{
            width:44px;
            height:44px;
            flex:0 0 44px;
            display:inline-flex;
            align-items:center;
            justify-content:center;
            border-radius:16px;
            color:#fff;
            background:rgba(255,255,255,.14);
            border:1px solid rgba(255,255,255,.20);
            font-size:19px;
        }
        .sv-note-item strong{
            display:block;
            font-size:14px;
            font-weight:950;
            line-height:1.35;
        }
        .sv-note-item span{
            display:block;
            margin-top:3px;
            color:rgba(255,255,255,.72);
            font-size:12px;
            line-height:1.45;
        }

        .sv-card.sv-over-limit{display:none;}
        .sv-view-all-wrap{
            position:relative;
            z-index:1;
            display:flex;
            align-items:center;
            justify-content:center;
            margin-top:24px;
        }
        .sv-view-all{
            display:inline-flex;
            align-items:center;
            justify-content:center;
            gap:10px;
            min-height:54px;
            padding:14px 26px;
            border-radius:999px;
            background:#fff;
            color:#0b4f9d!important;
            border:1px solid rgba(255,255,255,.85);
            text-decoration:none!important;
            font-weight:950;
            font-size:15px;
            box-shadow:0 20px 48px rgba(0,0,0,.18);
            transition:all .24s ease;
        }
        .sv-view-all:hover{
            transform:translateY(-3px);
            box-shadow:0 26px 58px rgba(0,0,0,.24);
            color:#063a79!important;
        }
        .sv-view-all i{font-size:17px;}
        .sv-view-all small{
            display:inline-flex;
            align-items:center;
            justify-content:center;
            min-width:28px;
            height:28px;
            padding:0 9px;
            border-radius:999px;
            color:#fff;
            background:linear-gradient(135deg,#0d63bf,#1b9df0);
            font-size:12px;
            font-weight:950;
        }

        @media (max-width:1199px){
            .sv-grid{grid-template-columns:repeat(3,minmax(0,1fr));}
            .sv-toolbar{grid-template-columns:1fr;}
            .sv-filters{justify-content:flex-start;}
            .sv-system-note{grid-template-columns:repeat(2,minmax(0,1fr));}
        }

