@import url('https://fonts.googleapis.com/css2?family=Vazirmatn:wght@400;700;900&display=swap');
*, *::before, *::after { box-sizing: border-box; }
:root { --bg-color: #f4f4f9; --text-color: #212529; --surface-color: #ffffff; --border-color: #ddd; --primary-color: #007bff; --primary-text-color: #ffffff; --header-color: #0033A0; --hr-color: #eee; }
body.dark-mode { --bg-color: #121212; --text-color: #e0e0e0; --surface-color: #1e1e1e; --border-color: #444; --primary-color: #1e90ff; --header-color: #589df; --hr-color: #333; }
body { font-family: 'Vazirmatn', sans-serif; text-align: center; padding: 20px; font-weight: 400; display: flex; flex-direction: column; min-height: 100vh; background-color: var(--bg-color); color: var(--text-color); transition: background-color 0.3s, color 0.3s; }
.main-header { display: flex; justify-content: center; align-items: center; gap: 20px; flex-wrap: wrap; }
h1, h2 { color: var(--header-color); font-weight: 700; }
form, #result { background: var(--surface-color); padding: 20px; border-radius: 8px; box-shadow: 0 2px 4px rgba(0,0,0,0.1); margin: 20px auto; width: 100%; max-width: 600px; border: 1px solid var(--border-color); transition: background-color 0.3s, border-color 0.3s; }
#result {min-height: 500px; margin: 0px; text-align: right; padding: 15px; }
select, button { font-family: 'Vazirmatn', sans-serif; padding: 12px; font-size: 16px; margin: 8px 0; border-radius: 5px; border: 1px solid var(--border-color); background-color: var(--surface-color); color: var(--text-color); width: 100%; }
button[type="submit"] { background-color: var(--primary-color); color: var(--primary-text-color); cursor: pointer; border: none; transition: background-color 0.2s; font-weight: 700; }
button[type="submit"]:hover { opacity: 0.9; }
hr { border: none; border-top: 1px solid var(--hr-color); margin: 30px auto; max-width: 600px; }
#result p { margin: 8px 10px; padding: 5px; font-size: 16px; border-right: 4px solid; }
.line-1 { border-color: #E60000; color: #E60000; } .line-2 { border-color: #0033A0; color: #0033A0; } .line-3 { border-color: #00AEEF; color: #00AEEF; } .line-4 { border-color: #FFD700; color: #FFD700; } .line-5 { border-color: #009933; color: #009933; } .line-6 { border-color: #E95498; color: #E95498; } .line-7 { border-color: #6A0DAD; color: #6A0DAD; }
.bold { font-weight: 900; }
.transfer-info { color: #d9534f; font-style: italic; font-weight: 700; margin: 15px 0 !important; text-align: center; border: none !important; }
footer { margin-top: auto; padding: 20px; color: #777; font-size: 14px; }
footer a { color: var(--primary-color); text-decoration: none; font-weight: bold; }
footer a:hover { text-decoration: underline; }
#theme-toggle { font-size: 24px; background: none; border: none; cursor: pointer; padding: 0 10px; line-height: 1; width: auto; }
.results-wrapper { display: none; }
.results-container { display: flex; flex-wrap: wrap; gap: 20px; align-items: stretch; /* مهم: ستون‌ها را هم قد می‌کند */ margin: 0 auto; max-width: 1200px; width: 100%; }

/* --- تغییرات اصلی در این بخش اعمال شده --- */
.path-details, .map-visual {
    flex: 1; 
    min-width: 300px;
    display: flex; /* این دو ستون را به فلکس تبدیل می‌کند */
    flex-direction: column; /* چیدمان داخلی آن‌ها را عمودی می‌کند */
}
#map {
    width: 100%;
    min-height: 500px; /* حداقل ارتفاع برای نقشه */
    flex-grow: 1; /* باعث می‌شود نقشه تمام فضای خالی والد خود را پر کند */
    background-color: var(--surface-color);
    border: 1px solid var(--border-color);
    border-radius: 8px;
}
/* --- پایان بخش تغییرات --- */

.map-container { background-color: var(--surface-color); border: 1px solid var(--border-color); border-radius: 8px; padding: 20px; margin: 40px auto; width: 100%; max-width: 900px; }
.map-container img { width: 100%; height: auto; border-radius: 5px; margin-top: 15px; }
@media (max-width: 768px) { 
    .results-container { flex-direction: column; }
    body { padding: 10px; } h1 { font-size: 24px; } h2 { font-size: 20px; } form, #result, .map-container { padding: 15px; } 
}