 @charset "utf-8";

/* CSS Document */

/*2026.4.30*/	

.life-box p{
  font-size:16px;
}
       .contacts-card {
            background-color:#1f4b9a;
            border-radius: 20px;
            padding: 20px;
        
            margin: 0 auto;
            color: #ffffff;
        }

        .contacts-header {
            display: flex;
            align-items: center;
            gap: 1rem;
            margin-bottom: 10px;
        }

   

        .contacts-header h2 {
            font-size: 20px;
            font-weight: 700;
        }
        .contacts-header h2  svg{
        	margin-right: 10px;
        }

        .contacts-grid {
            display: grid;
            grid-template-columns: repeat(2, 1fr);
            gap: 1.5rem;    margin-top: 15px;
        }

        .contact-item {
            background-color: rgba(255, 255, 255, 0.12);
            border-radius: 16px;
            padding: 20px;
        }

        .contact-item h3 {
            font-size: 16px;
            font-weight: 600;
            margin-bottom: 1rem;
            line-height: 1.3;
        }

        .contact-item p {
            font-size: 14px;
            opacity: 0.9;
            margin-bottom: 0.1rem;
            line-height: 1.4;
            color: #fff;
            
        }
        
        /*2*/
             .building {
             	margin-top: 20px;
            box-shadow:1px 0px 5px 1px rgb(0 0 0 / .05);
            padding: 20px;
            background: #fff;
            
            border-radius: 15px;
        }

        .title1 {
            display: flex;
            align-items: center;
            font-size: 20px;
            font-weight: 600;
            color: #1e293b;
            margin-bottom: 1rem;
        }

        .title1 svg {
            margin-right: 10px;
            color:#4a90d9;
        }

        .building-section {
            display: flex;
            flex-wrap: wrap;
            align-items: flex-start;
            margin-bottom: 1rem;
            background-color: #f8fafc;
            border-radius: 8px;
            padding: 1.25rem;
            gap: 1rem;
        }

        .building-name {
            font-size: 16px;
            font-weight: 700;
            color: #1e293b;
            flex: 0 0 100px;
            padding-top: 0.25rem;
        }

        .tags-container {
            display: flex;
            flex-wrap: wrap;
            gap: 0.75rem;
            flex: 1;
        }

        .tag {
            background-color: #ffffff;
            border: 1px solid #e2e8f0;
            border-radius: 6px;
            padding: 0.5rem 1rem;
            font-size: 14px;
            color: #334155;
            white-space: nowrap;
        }
        /*3*/
         /* 通用卡片样式 */
        .card {
            background: #ffffff;
         border: none;
            border-radius: 15px;
            padding:20px;
            margin-bottom: 1.5rem;
              	
            box-shadow:1px 0px 5px 1px rgb(0 0 0 / .05);
        }

        .card-header {
            display: flex;
            align-items: center;
            /*gap: 0.75rem;*/
            font-size: 18px;
            font-weight: 600;
            color: #1e3a5f;
            margin-bottom: 20px;
            background: none;
            border: none;
            padding: 0;
            text-align: left;
        }

        .card-header  svg {
            margin-right: 10px;
            color:#4a90d9;
        }

        /*  Dining Services 模块 */
        .dining-grid {
            display: grid;
            grid-template-columns: repeat(3, 1fr);
            gap: 1rem;
            margin-bottom: 10px;
        }

        .meal-item {
            background: #f7f9fc;
            border-radius: 10px;
            padding: 1.5rem 1rem;
            text-align: center;
        }

        .meal-name {
            font-size: 14px;
            color: #333;
            margin-bottom: 0.8rem;
        }

        .meal-time {
            font-size: 20px;
            font-weight: 700;
            color: #1e3a5f;
        }

       p.location-text {
            font-size: 14px;
            color: #555;
            margin-bottom: 5px;
           
        }

        .delivery-notice {
            background-color: #fffde7;
            border: 1px solid #ffe082;
            border-radius: 10px;
            padding: 10px;
            font-size: 12px;
            color: #795548;
        }

        .delivery-notice strong {
            color: #5d4037;
        }

        /* 双列模块（Reading Room + Express Delivery） */
        .two-col-grid {
            display: grid;
            grid-template-columns: repeat(2, 1fr);
            gap: 1.5rem;
            margin-bottom: 1.5rem;
        }

        .small-card {
            background: #ffffff;
            border: none;
            box-shadow:1px 0px 5px 1px rgb(0 0 0 / .05);
            border-radius: 12px;
            padding: 1.5rem;
            
        }

        .small-card .card-header {
            margin-bottom: 1rem;
            padding: 0;
            /*gap:0;*/
        }

        .small-card p {
            font-size: 16px;
            color: #333;
            margin-bottom: 0.5rem;
            line-height: 1.5;
        }

        /* Public Instrument Platform 模块 */
        .instrument-grid {
            display: grid;
            grid-template-columns: 1fr 1fr;
            gap: 1rem;
            margin-bottom: 1rem;
        }

        .instrument-info p {
            font-size: 16px;
            color: #333;
            margin-bottom: 0.5rem;
            line-height: 1.5;
        }

        .instrument-info a {
            color: #1976d2;
            text-decoration: none;
        }

        p.instrument-footer {
            font-size: 1rem;
            color: #666;
            margin-bottom: 0;
        }
/*4*/
 
 /* 第一部分：Student Apartment Guide */
        .apartment-guide-wrapper {
            display: grid;
            grid-template-columns: 1fr 1fr;
            gap:10px 32px ;
        }
        .section-title {
            font-size: 16px;
            font-weight: 600;
            color: #1e293b;
            margin-bottom: 16px;
        }
       .card table {
            width: 100%;
            border-collapse: collapse;
        }
       .card table th, table td {
            padding: 12px 8px;
            text-align: left;
          font-size: 14px;
            
        }
       .card table th {
            background-color: #f8fafc;
            font-weight: 600;
            color: #334155;
            border-radius: 6px;
        }
       .card table tr td {
            color: #334155;
            border-bottom: 1px solid #f1f5f9;
border-color:#f1f5f9;
        }
      .card  table tr:last-child td {
            /*border-bottom: none;*/
        }
        p.note-text {
            margin-top: 1px;
            color: #64748b;
            font-size: 14px;
            margin-bottom: 0;
        }
        /* 第二部分：Apartment Regulations */
        ul.regulations-list {
            list-style: none;
            color: #334155;
            line-height: 1.8;
            padding-left: 0 !important;  margin-bottom: 1px;
        }
        .regulations-list li {
            position: relative;
            padding-left: 2px;
            margin-bottom: 8px;
            text-align: left;
            list-style: none !important;
        }
        /*.regulations-list li::before {
            content: ">";
            position: absolute;
            left: 0;
            color: #c9a227;
          
        }*/
.regulations-list li em{
	color: #c9a227;
	margin-right: 10px;
}
ul.regulations-list li p{
     font-size: 16px;    margin-bottom: 2px;
}
/*5*/
 /* 校园卡部分 */
        .campus-card-desc {
            color: #374151;
            line-height: 1.3;
            margin-bottom: 16px;
            font-size: 16px;
        }
         .campus-card-desc  p{
         	font-size: 16px;
         	line-height: 26px;
         	margin-bottom: 5px;
         }
        .email-template {
            background-color: #f8fafc;
            padding: 20px;
            border-radius: 8px;
            color: #374151;
        }
        .email-template h4 {
            font-size: 16px;
            font-weight: 600;
            margin-bottom: 12px;
        }
        .email-template .subject,
        .email-template .body {
            margin-bottom: 12px;
            line-height: 1.6;
        }
        .email-template .send-to {
            color: #4a90d9;
            font-weight: 500;
        }
        /* 下方两栏布局 */
        .bottom-row {
            display: grid;
            grid-template-columns: 1fr 1fr;
            gap: 24px;
        }
        .info-item {
            margin-bottom: 10px;
            color: #374151;
        }
        .info-item strong {
            color: #1e293b;
        }
        .disinfection-note {
            margin-top: 16px;
            background-color: #fffbeb;
            padding: 8px 12px;
            border-radius: 6px;
            color: #d97706;
            font-size: 14px;
        }
/*6*/
 .info-line {
            font-size: 14px;
            color: #475569;
            margin-bottom: 12px;
        }
        .facilities-grid {
            display: grid;
            grid-template-columns: repeat(4, 1fr);
            gap: 24px;
            margin-bottom: 32px;
        }
        .facility-item {
            background-color: #f8fafc;
            border-radius: 16px;
            padding:  16px;
            text-align: center;
        }
        .facility-item h3 {
            font-size: 16px;
            font-weight: 600;
            color: #1e293b;
            margin-bottom: 12px;
        }
        .facility-item p {
            font-size: 14px;
            color: #64748b;
            margin-bottom: 0;
        }
        p.booking-info {
            font-size: 14px;
            color: #475569;
        }
        .booking-info a {
            color: #4a90d9;
            text-decoration: none;
            font-weight: 500;
        }
/*7*/
 .bus-card {
            background: #ffffff;
            border-radius: 12px;
            padding: 24px;
            box-shadow: 0 1px 3px rgba(0,0,0,0.08);
            border: 1px solid #f3f4f6;
            max-width: 1200px;
        }
        
      
       
        /* 时段标题 */
        .section-title {
            font-size: 16px;
            font-weight: 600;
            color: #ca8a04;
            margin: 8px 0 12px;
            text-transform: uppercase;
        }
        /* 班车行程项 */
        .trip-item {
            display: flex;
            align-items: center;
            gap: 12px;
            padding: 10px 12px;
            border-radius: 6px;
            margin-bottom: 8px;
        }
        .trip-item.outbound {
            background-color: #eff6ff;
        }
        .trip-item.return {
            background-color: #f0fdf4;
        }
        .trip-type {
            font-size: 14px;
            font-weight: 600;
            padding: 3px 8px;
            border-radius: 4px;
        }
        .trip-item.outbound .trip-type {
            background-color: #dbeafe;
            color: #1d4ed8;
        }
        .trip-item.return .trip-type {
            background-color: #dcfce7;
            color: #16a34a;
        }
        .trip-text {
            font-size: 16px;
            color: #374151;
        }
        /* 信息区域 */
        .info-block {
            margin-top: 24px;
            padding: 16px;
            background-color: #f8fafc;
            border-radius: 8px;
        }
        .info-block h4 {
            font-size: 16px;
            font-weight: 600;
            color: #1e293b;
            margin-bottom: 12px;
        }
        ul.pickup-points {
            list-style: disc;
            padding-left: 20px;
            color: #374151;
            margin-bottom: 12px;
            line-height: 1.6;
        }
 ul.pickup-points li p{
   font-size: 16px; margin-bottom: 1px;
}
        .note-text {
            color: #374151;
            line-height: 1.6;
        }
        .note-text strong {
            color: #ca8a04;
        }
 .note-text p{
 	margin-bottom: 0;
 	font-size: 16px;
 }


/*8*/
/* 响应式双列 → 手机单列 */
        .row-cards {
            display: grid;
            grid-template-columns: 1fr 1fr;
            gap: 20px;
        }
       
       

        /* 列表样式 */
        .info-list {
            list-style: none;
            color: #374151;
            line-height: 1.6;
        }
        .info-list li {
            position: relative;
            padding-left: 20px;
            margin-bottom: 12px;
        }
        .info-list li::before {
            content: ">";
            position: absolute;
            left: 0;
            color: #3b82f6;
            font-weight: bold;
        }

        /* 电费提醒 */
        .reminder {
            margin-top: 16px;
            background-color: #fffbeb;
            padding: 10px;
            border: 1px solid #fef3c7;
            border-radius: 6px;
            color: #b45309;
            font-size: 14px;
        }

        /* 响应式双栏列表 → 手机单列 */
        .two-column-list {
            display: grid;
            grid-template-columns: 1fr 1fr;
            gap: 24px;
            text-align: left;
        }
      
        .column-section h4 {
            font-size: 16px;
            font-weight: 600;
            color: #1e293b;
            margin-bottom: 12px;
        }
        .column-section ul {
            list-style: disc;
            padding-left: 20px;
            color: #374151;
            line-height: 1.8;
 margin-bottom: 10px;
        }
  .column-section ul li p{
 margin-bottom: 0;
    font-size: 16px;
}
        /* 底部设施信息 */
        .facility-info p {
            color: #374151;
            line-height: 1.6;
            margin-bottom: 8px;
            font-size: 16px;
            
        }
        .facility-info strong {
            color: #1e293b;
        }



        /* 响应式适配 */
        @media (max-width: 900px) {
            .dining-grid {
                grid-template-columns: 1fr;
            }
            .two-column-list {
                grid-template-columns: 1fr;
            }
            .two-col-grid {
                grid-template-columns: 1fr;
            }
            .instrument-grid {
                grid-template-columns: 1fr;
            }
       .row-cards {
                grid-template-columns: 1fr;
            }
            .contacts-grid {
                grid-template-columns: 1fr;
            }
.contacts-header h2,.title1{
	font-size: 18px;
	
}
.view-cnt ul li{
	text-align: left;
}
.trip-text{
	font-size: 14px;
}
.facilities-grid{
	grid-template-columns: 1fr;
}
    .bottom-row{
    	grid-template-columns: 1fr;
    	gap:2;
    }  
    .info-item{
    	font-size: 16px !important;
    }
    .meal-time{
    	font-size: 16px;
    	
    }
  .apartment-guide-wrapper{
  	/*grid-template-columns: 1fr;*/
  	display: block;
  }  
    
    
         
        }
 	
 	
 	