        /* 메인 컨테이너 (모바일 화면 비율 정도의 너비) */
        .container {
            width: 100%;
            max-width: 600px;
            background-color: #ffffff;
            padding: 40px 20px;
            box-shadow: 0 4px 10px rgba(0,0,0,0.05);
			margin:auto;
        }

        /* 1 & 2. 상단 로고 이미지 영역 */
        .logo-area {
            text-align: center;
            margin-bottom: 40px;
        }
        .logo-area .logo{ width:100%; max-width:180px;}
        .main-logo {
            width: 120px;
            height: auto;
            margin-bottom: 10px;
            display: block;
            margin: 0 auto 10px auto;
        
        }
        .sub-logo {
            width: 180px;
            height: auto;
            display: block;
            margin: 0 auto;
             
        }

        /* 입력 폼 영역 */
        .input-group {
            display: flex;
            align-items: center;
            margin-bottom: 20px;
        }
        .input-group label {
            width: 60px;
            font-size: 16px;
            color: #888;
            font-weight: 500;
        }
        .input-wrapper {
            flex: 1;
            display: flex;
            align-items: center;
            border: 1px solid #ccc;
            padding: 5px 10px;
            height: 40px;
        }
        .input-wrapper input {
            flex: 1;
            border: none;
            outline: none;
            font-size: 16px;
            width: 100%;
        }
        /* 돋보기 아이콘 버튼 */
        .search-btn {
            background: none;
            border: none;
            cursor: pointer;
            padding: 5px;
            display: flex;
            align-items: center;
            justify-content: center;
        }
        .search-btn svg {
            width: 24px;
            height: 24px;
            stroke: #ff5e00; /* 오렌지색 */
            stroke-width: 3;
        }

        /* 구분선 */
        .divider {
            height: 1px;
            background-color: #eaeaea;
            margin: 20px 0;
        }

        /* 약관 영역 (스크롤 디자인 포함) */
        .terms-area {
            border: 1px solid #ccc;
            padding: 15px;
            margin-top: 30px;
            margin-bottom: 15px;
            height: 250px;
            overflow-y: auto;
            font-size: 13px;
            color: #aaa;
            line-height: 1.6;
        }
        
        /* 웹킷(크롬, 사파리 등) 커스텀 스크롤바 디자인 */
        .terms-area::-webkit-scrollbar {
            width: 6px;
        }
        .terms-area::-webkit-scrollbar-track {
            background: #f1f1f1; 
        }
        .terms-area::-webkit-scrollbar-thumb {
            background: #ff3c00; /* 스크롤바 오렌지색/빨간색 */
        }

        /* 커스텀 체크박스 영역 */
        .checkbox-group {
            display: flex;
            align-items: center;
            margin-bottom: 40px;
        }
        .checkbox-group input[type="checkbox"] {
            display: none; /* 기본 체크박스 숨김 */
        }
        .checkbox-group label {
            display: flex;
            align-items: center;
            cursor: pointer;
            font-size: 14px;
            color: #b3b3b3;
        }
        /* 체크박스 사각형 디자인 */
        .checkbox-group label::before {
            content: '';
            display: inline-block;
            width: 18px;
            height: 18px;
            border: 1px solid #ccc;
            margin-right: 10px;
            background-color: #fff;
        }
        /* 체크되었을 때 빨간색 V자 (SVG 배경 사용) */
        .checkbox-group input[type="checkbox"]:checked + label::before {
            background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23ff0000' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'%3E%3C/polyline%3E%3C/svg%3E");
            background-size: 80%;
            background-position: center;
            background-repeat: no-repeat;
        }

        /* 하단 텍스트 */
        .footer-text {
            text-align: center;
            color: #ff6633;
            font-size: 24px;
            font-weight: 300; /* 얇은 폰트 */
            letter-spacing: 2px;
            font-family: 'Arial', sans-serif;
        }
		
		
		
		
		/* sub */
		        /* 주자 정보 */
        .runner-info {
            text-align: center;
            color: #b3b3b3;
            font-size: 15px;
            margin-bottom: 10px;
        }
        .highlight {
            color: #ff4500;
        }

        /* 메인 기록 */
        .main-time {
            text-align: center;
            color: #ff4500;
            font-size: 64px;
            font-weight: 100; /* 매우 얇은 폰트 적용 */
            line-height: 1.1;
            margin-bottom: 20px;
            font-family: 'Arial', sans-serif; /* 숫자는 기본 산세리프 폰트가 더 깔끔함 */
        }

        /* 페이스/속도 정보 */
        .pace-speed {
            text-align: center;
            color: #b3b3b3;
            font-size: 14px;
            line-height: 1.6;
            margin-bottom: 30px;
        }

        /* 기록 테이블 */
        .record-table {
            width: 100%;
            border-collapse: collapse;
            text-align: center;
            margin-bottom: 40px;
        }
        .record-table th, .record-table td {
            padding: 15px 5px;
            font-size: 13px;
            border-bottom: 1px solid #eaeaea;
        }
        .record-table tr:first-child {
            border-top: 1px solid #eaeaea;
        }
        .record-table th {
            color: #b3b3b3;
            font-weight: 400;
            border-right: 1px solid #eaeaea;
            width: 25%;
        }
        .record-table td {
            color: #ff4500;
            font-weight: 300;
            width: 25%;
            border-right: 1px solid #eaeaea;
        }
        .record-table td:last-child {
            border-right: none;
        }

        /* 그래프 영역 */
        .graph-container {
            width: 100%;
            margin-bottom: 50px;
            position: relative; 
			overflow-x:auto;
			  border-top: 1px dotted #ff7f50;
			  border-bottom: 1px dotted #ff7f50;
        }

        /* 외부 링크 버튼 (기록증) */
        .btn-certificate {
            display: block;
            width: 80%;
            margin: 0 auto;
            padding: 15px 0;
            border: 1px solid #ff4500;
            border-radius: 40px;
            text-align: center;
            color: #ff4500;
            text-decoration: none;
            font-size: 18px;
            font-weight: 300;
            background-color: #fff;
            transition: all 0.3s;
        }
        .btn-certificate:hover {
            background-color: #fff5f0;
        }
		
		
		
		
		

        /* 타이틀 바 */
        .main-title {
            background-color: #ff4500;
            color: #ffffff;
            text-align: center;
            padding: 12px;
            border-radius: 30px;
            font-size: 16px;
            font-weight: 400;
            letter-spacing: 1px;
            margin-bottom: 30px;
        }

        /* 구분선 (타원형 텍스트 포함) */
        .section-divider {
            display: flex;
            align-items: center;
            text-align: center;
            margin: 25px 0 15px 0;
        }
        .section-divider::before,
        .section-divider::after {
            content: '';
            flex: 1;
            border-bottom: 1px dotted #ff3c00; /* 점선 색상 */
        }
        .section-divider span {
            color: #ff3c00;
            padding: 3px 20px;
            border: 1px solid #ff3c00;
            border-radius: 20px;
            font-size: 20px;
            font-weight: 300;
            margin: 0 10px;
            background: #fff;
        }

        /* 정보 리스트 공통 (좌우 배치) */
        .info-row {
            display: flex;
            justify-content: space-between;
            margin-bottom: 12px;
            font-size: 1.4em;
            font-weight: 300;
            padding: 0 10px;
        }
        .info-label { color: #000; }
        .info-value { color: #000; }

        /* 구간별 기록 테이블 (세로형) */
        .splits-table {
            width: 100%;
            border-collapse: collapse;
            text-align: center;
            margin-bottom: 30px;
        }
        .splits-table th {
            color: #ff3c00;
            font-weight: 300;
            font-size: 1.4em;
            padding: 15px 5px;
        }
        .splits-table td {
            color: #000;
            font-weight: 300;
            font-size: 1.3em;
            padding: 8px 5px;
        }		