/* ========================================
   LEKZYTTP AUTO-RESPONSIVE SCREEN ADJUSTER
   Automatically detects and adjusts ALL pages to fit perfectly
   ======================================== */

/* Root Variables for Dynamic Scaling */
:root {
    --screen-width: 100vw;
    --screen-height: 100vh;
    --container-max-width: min(95vw, 1400px);
    --container-padding: clamp(10px, 2vw, 30px);
    --font-base: clamp(12px, 1.2vw, 16px);
    --font-small: clamp(10px, 1vw, 14px);
    --font-large: clamp(16px, 1.5vw, 22px);
    --font-xl: clamp(20px, 2vw, 28px);
    --spacing-sm: clamp(8px, 1vw, 15px);
    --spacing-md: clamp(15px, 2vw, 25px);
    --spacing-lg: clamp(25px, 3vw, 40px);
    --card-height: clamp(200px, 40vh, 400px);
    --button-height: clamp(35px, 5vh, 50px);
    --input-height: clamp(35px, 4vh, 45px);
}

/* Universal Screen Optimization */
* {
    box-sizing: border-box;
    max-width: 100%;
}

html, body {
    margin: 0;
    padding: 0;
    width: 100vw;
    min-height: 100vh;
    overflow-x: hidden;
    font-size: var(--font-base);
    line-height: 1.4;
}

/* Container Auto-Adjustment */
.container, .container-fluid {
    width: 100% !important;
    max-width: var(--container-max-width) !important;
    margin: 0 auto !important;
    padding: var(--container-padding) !important;
}

/* Dynamic Grid System */
.row {
    margin: 0 !important;
    width: 100% !important;
    display: flex !important;
    flex-wrap: wrap !important;
    gap: var(--spacing-sm) !important;
}

.col, .col-12, .col-md-6, .col-md-4, .col-md-3, .col-lg-4, .col-lg-3, .col-lg-6 {
    padding: 0 !important;
    flex: 1 1 auto;
    min-width: 250px;
    max-width: none;
}

/* Admin Dashboard Responsive Grid */
.admin-dashboard-grid {
    display: grid !important;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)) !important;
    gap: 15px !important;
    width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
    justify-content: stretch !important;
    align-content: start !important;
}

/* Admin Card Specific Styles */
.admin-function-card {
    width: 100% !important;
    height: 130px !important;
    display: flex !important;
    flex-direction: column !important;
    justify-content: center !important;
    align-items: center !important;
    text-align: center !important;
    padding: 15px !important;
    margin: 0 !important;
    border-radius: 12px !important;
    transition: all 0.3s ease !important;
    overflow: hidden !important;
    text-decoration: none !important;
    position: relative !important;
    background: linear-gradient(135deg, #1a1f2e, #252a3d) !important;
    border: 2px solid !important;
}

.admin-function-card:hover {
    transform: translateY(-2px) !important;
    box-shadow: 0 8px 25px rgba(220, 53, 69, 0.3) !important;
}

/* Responsive breakpoints for admin grid */
@media (max-width: 1200px) {
    .admin-dashboard-grid {
        grid-template-columns: repeat(auto-fit, minmax(250px, 1fr)) !important;
        gap: 12px !important;
    }
}

@media (max-width: 768px) {
    .admin-dashboard-grid {
        grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)) !important;
        gap: 10px !important;
    }
    
    .admin-function-card {
        height: 110px !important;
        padding: 12px !important;
    }
    
    .admin-function-card i {
        font-size: 1.5rem !important;
    }
}

@media (max-width: 480px) {
    .admin-dashboard-grid {
        grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)) !important;
        gap: 8px !important;
    }
    
    .admin-function-card {
        height: 100px !important;
        padding: 10px !important;
    }
    
    .admin-function-card i {
        font-size: 1.3rem !important;
    }
    
    .admin-function-card div {
        font-size: 0.75rem !important;
    }
}

/* Ensure no empty space and proper wrapping */
@media (min-width: 1400px) {
    .admin-dashboard-grid {
        grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)) !important;
    }
}

/* Force grid to use all available space */
.admin-dashboard-grid::after {
    content: '';
    grid-column: 1 / -1;
    height: 0;
}

/* User Interface Responsive Breakpoints */
@media (max-width: 1400px) {
    .card-grid-container {
        grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)) !important;
        gap: 20px !important;
    }
    
    .tool-selection-grid {
        grid-template-columns: repeat(auto-fit, minmax(320px, 1fr)) !important;
        gap: 20px !important;
    }
}

@media (max-width: 1024px) {
    .card-grid-container {
        grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)) !important;
        gap: 18px !important;
    }
    
    .tool-selection-grid {
        grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)) !important;
        gap: 18px !important;
    }
    
    .api-config-card {
        padding: 20px !important;
        min-height: 180px !important;
    }
    
    .tool-card {
        padding: 25px !important;
        min-height: 220px !important;
    }
}

@media (max-width: 768px) {
    .card-grid-container {
        grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)) !important;
        gap: 15px !important;
    }
    
    .tool-selection-grid {
        grid-template-columns: 1fr !important;
        gap: 15px !important;
    }
    
    .api-config-card {
        padding: 18px !important;
        min-height: 160px !important;
    }
    
    .tool-card {
        padding: 20px !important;
        min-height: 200px !important;
    }
}

@media (max-width: 480px) {
    .card-grid-container {
        grid-template-columns: 1fr !important;
        gap: 12px !important;
    }
    
    .api-config-card {
        padding: 15px !important;
        min-height: 140px !important;
    }
    
    .tool-card {
        padding: 18px !important;
        min-height: 180px !important;
    }
}

/* Modal and Popup Responsive Layout */
.modal-content {
    max-width: min(90vw, 600px) !important;
    margin: 0 auto !important;
    border-radius: 15px !important;
}

.modal-body {
    padding: var(--spacing-md) !important;
}

/* Configuration Form Layout */
.config-form-container {
    max-width: 800px !important;
    margin: 0 auto !important;
    padding: var(--spacing-md) !important;
}

.config-form-grid {
    display: grid !important;
    grid-template-columns: repeat(auto-fit, minmax(250px, 1fr)) !important;
    gap: var(--spacing-md) !important;
    margin: var(--spacing-md) 0 !important;
}

/* Professional Button Layout */
.button-group {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: var(--spacing-sm) !important;
    justify-content: center !important;
    align-items: center !important;
    margin: var(--spacing-md) 0 !important;
}

.button-group .btn {
    flex: 0 1 auto !important;
    min-width: 120px !important;
    margin: 0 !important;
}

/* Centered Content Layout */
.centered-content {
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: center !important;
    text-align: center !important;
    min-height: 60vh !important;
    padding: var(--spacing-lg) !important;
}

/* Professional Text Sizing */
.card-title {
    font-size: clamp(1.1rem, 2.5vw, 1.4rem) !important;
    line-height: 1.3 !important;
    margin-bottom: var(--spacing-sm) !important;
}

.card-subtitle {
    font-size: clamp(0.9rem, 2vw, 1.1rem) !important;
    opacity: 0.8 !important;
    margin-bottom: var(--spacing-md) !important;
}

.card-text {
    font-size: var(--font-base) !important;
    line-height: 1.5 !important;
    margin-bottom: var(--spacing-sm) !important;
}

/* Professional User Interface Layout System */
.main-content-container {
    max-width: 1400px !important;
    margin: 0 auto !important;
    padding: var(--container-padding) !important;
    width: 100% !important;
}

/* Responsive Cards System */
.card, .glass-card, .control-panel-card, .api-control-row {
    width: 100% !important;
    max-width: 100% !important;
    margin-bottom: var(--spacing-md) !important;
    padding: var(--spacing-md) !important;
    min-height: auto !important;
    border-radius: clamp(8px, 1vw, 15px) !important;
}

/* Professional Card Grid Layout */
.card-grid-container {
    display: grid !important;
    grid-template-columns: repeat(auto-fit, minmax(320px, 1fr)) !important;
    gap: var(--spacing-md) !important;
    width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
    align-items: start !important;
}

/* API Configuration Cards */
.api-config-card {
    background: linear-gradient(135deg, rgba(255,255,255,0.1), rgba(255,255,255,0.05)) !important;
    border: 2px solid rgba(255,255,255,0.2) !important;
    border-radius: 15px !important;
    backdrop-filter: blur(15px) !important;
    padding: 25px !important;
    margin: 0 !important;
    width: 100% !important;
    min-height: 200px !important;
    max-height: none !important;
    display: flex !important;
    flex-direction: column !important;
    justify-content: space-between !important;
    transition: all 0.3s ease !important;
}

.api-config-card:hover {
    transform: translateY(-3px) !important;
    border-color: rgba(255,255,255,0.4) !important;
    box-shadow: 0 10px 30px rgba(0,0,0,0.3) !important;
}

/* Tool Selection Page Layout */
.tool-selection-grid {
    display: grid !important;
    grid-template-columns: repeat(auto-fit, minmax(350px, 1fr)) !important;
    gap: 25px !important;
    margin: var(--spacing-lg) 0 !important;
    width: 100% !important;
}

.tool-card {
    background: linear-gradient(135deg, rgba(255,255,255,0.1), rgba(255,255,255,0.05)) !important;
    border: 2px solid rgba(255,255,255,0.2) !important;
    border-radius: 20px !important;
    padding: 30px !important;
    text-align: center !important;
    transition: all 0.3s ease !important;
    min-height: 250px !important;
    display: flex !important;
    flex-direction: column !important;
    justify-content: center !important;
    align-items: center !important;
}

.tool-card:hover {
    transform: translateY(-5px) !important;
    border-color: rgba(255,255,255,0.5) !important;
    box-shadow: 0 15px 40px rgba(0,0,0,0.4) !important;
}

/* Auto-Adjusting Forms */
.form-control, input[type="text"], input[type="email"], input[type="password"], textarea, select {
    width: 100% !important;
    height: var(--input-height) !important;
    font-size: var(--font-base) !important;
    padding: var(--spacing-sm) !important;
    border-radius: clamp(5px, 0.5vw, 8px) !important;
}

textarea {
    min-height: clamp(80px, 15vh, 150px) !important;
    resize: vertical;
}

/* Button Auto-Sizing */
.btn, button {
    min-height: var(--button-height) !important;
    padding: var(--spacing-sm) var(--spacing-md) !important;
    font-size: var(--font-base) !important;
    border-radius: clamp(5px, 0.5vw, 8px) !important;
    white-space: normal;
    overflow: visible;
    word-wrap: break-word;
    text-align: center;
}

.btn-lg {
    min-height: clamp(45px, 6vh, 60px) !important;
    font-size: var(--font-large) !important;
}

.btn-sm {
    min-height: clamp(30px, 4vh, 40px) !important;
    font-size: var(--font-small) !important;
}

/* Admin Dashboard Buttons - Compact Square Design */
.admin-card .btn {
    height: 65px !important;
    min-height: 65px !important;
    max-height: 65px !important;
    padding: 6px 4px !important;
    white-space: normal !important;
    overflow: visible !important;
    word-wrap: break-word !important;
    line-height: 1.1 !important;
    font-size: 0.65rem !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: center !important;
    margin-bottom: 8px !important;
}

.admin-card .btn i {
    font-size: 0.9rem !important;
    margin-bottom: 2px !important;
    display: block !important;
}

.admin-card .btn strong {
    font-size: 0.55rem !important;
    font-weight: 600 !important;
    margin-bottom: 1px !important;
    text-align: center !important;
    line-height: 1.0 !important;
}

.admin-card .btn small {
    font-size: 0.45rem !important;
    opacity: 0.7;
    text-align: center !important;
    line-height: 1.0 !important;
}

/* Typography Auto-Scaling */
h1 { font-size: clamp(24px, 3vw, 36px) !important; line-height: 1.2; }
h2 { font-size: clamp(20px, 2.5vw, 28px) !important; line-height: 1.2; }
h3 { font-size: clamp(18px, 2vw, 24px) !important; line-height: 1.3; }
h4 { font-size: clamp(16px, 1.8vw, 20px) !important; line-height: 1.3; }
h5 { font-size: clamp(14px, 1.5vw, 18px) !important; line-height: 1.4; }
h6 { font-size: clamp(12px, 1.3vw, 16px) !important; line-height: 1.4; }

p, span, div, label { 
    font-size: var(--font-base) !important; 
    line-height: 1.4;
}

small, .small { 
    font-size: var(--font-small) !important; 
}

/* Navbar Auto-Height */
.navbar {
    height: clamp(60px, 8vh, 80px) !important;
    padding: var(--spacing-sm) var(--container-padding) !important;
}

.navbar-brand {
    font-size: var(--font-large) !important;
}

/* Progress Bar Auto-Sizing */
.progress {
    height: clamp(20px, 3vh, 30px) !important;
    border-radius: clamp(10px, 1vh, 15px) !important;
}

/* Modal Auto-Sizing */
.modal-dialog {
    max-width: clamp(300px, 90vw, 600px) !important;
    margin: clamp(10px, 5vh, 30px) auto !important;
}

.modal-content {
    border-radius: clamp(8px, 1vw, 15px) !important;
}

/* Table Responsiveness */
.table-responsive {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
}

table {
    font-size: var(--font-small) !important;
    width: 100% !important;
}

th, td {
    padding: var(--spacing-sm) !important;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    max-width: 150px;
}

/* Tool-Specific Adjustments */
.tool-card {
    min-height: var(--card-height) !important;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
}

.api-selection-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
    gap: var(--spacing-md);
    width: 100%;
}

/* Live Processing Pages */
.live-progress-container {
    max-height: clamp(300px, 50vh, 600px) !important;
    overflow-y: auto;
}

.progress-log {
    height: clamp(200px, 40vh, 500px) !important;
    overflow-y: auto;
    font-size: var(--font-small) !important;
}

/* Admin Panel Adjustments */
.admin-header {
    height: clamp(60px, 8vh, 80px) !important;
}

.api-control-row {
    min-height: clamp(60px, 8vh, 80px) !important;
    display: flex;
    align-items: center;
}

.toggle-switch {
    transform: scale(clamp(0.8, 1vw, 1.2));
}

/* Screen Size Specific Adjustments */
@media (max-width: 576px) {
    :root {
        --container-padding: 10px;
        --font-base: 14px;
        --spacing-md: 10px;
    }
    
    .col-md-6, .col-md-4, .col-md-3 {
        flex: 0 0 100% !important;
        max-width: 100% !important;
    }
    
    .btn {
        width: 100% !important;
        margin-bottom: 10px !important;
    }
    
    .navbar-brand {
        font-size: 16px !important;
    }
}

@media (min-width: 577px) and (max-width: 768px) {
    .col-md-6 {
        flex: 0 0 50% !important;
        max-width: 50% !important;
    }
    
    .col-md-4 {
        flex: 0 0 50% !important;
        max-width: 50% !important;
    }
}

@media (min-width: 769px) and (max-width: 1024px) {
    .col-md-4 {
        flex: 0 0 33.333333% !important;
        max-width: 33.333333% !important;
    }
    
    .col-md-6 {
        flex: 0 0 50% !important;
        max-width: 50% !important;
    }
}

@media (min-width: 1025px) {
    :root {
        --container-max-width: 1200px;
    }
}

/* Ultra-wide screen adjustments */
@media (min-width: 1920px) {
    :root {
        --container-max-width: 1400px;
        --font-base: 16px;
        --spacing-lg: 40px;
    }
}

/* Height-based adjustments */
@media (max-height: 600px) {
    :root {
        --spacing-md: 10px;
        --card-height: 180px;
        --button-height: 35px;
    }
    
    .navbar {
        height: 50px !important;
    }
}

@media (min-height: 900px) {
    :root {
        --card-height: 350px;
        --spacing-lg: 35px;
    }
}

/* Print optimization */
@media print {
    * {
        font-size: 12px !important;
    }
    
    .navbar, .btn, button {
        display: none !important;
    }
    
    .container {
        max-width: 100% !important;
        padding: 0 !important;
    }
}

/* High DPI display adjustments */
@media (-webkit-min-device-pixel-ratio: 2), (min-resolution: 192dpi) {
    :root {
        --font-base: 15px;
    }
}

/* Landscape mobile adjustments */
@media (max-height: 500px) and (orientation: landscape) {
    .navbar {
        height: 45px !important;
    }
    
    .card, .glass-card {
        padding: 15px !important;
    }
    
    .btn {
        height: 35px !important;
        font-size: 14px !important;
    }
}

/* Focus and accessibility */
*:focus {
    outline: 2px solid #007bff !important;
    outline-offset: 2px !important;
}

/* Smooth transitions for all adjustments */
* {
    transition: all 0.2s ease-in-out;
}

/* Utility classes for manual adjustments */
.fit-screen { width: 100vw !important; height: 100vh !important; }
.fit-width { width: 100% !important; }
.fit-height { height: 100% !important; }
.auto-scroll { overflow: auto !important; }