/* Modern Dark UI for MoviesNow */
:root {
    --bg-color: #0e0f13;
    --surface-1: #14161c;
    --surface-2: #1b1f27;
    --surface-3: #232936;
    --text-1: #e8ecf1;
    --text-2: #aab3bf;
    --text-3: #7a8493;
    --primary: #ff3b30;
    --primary-600: #e03229;
    --primary-700: #c62b23;
    --accent: #6ca1ff;
    --success: #22c55e;
    --warning: #f59e0b;
    --danger: #ef4444;
    --border: #2a3040;
    --shadow: 0 10px 30px rgba(0,0,0,0.35);
    --radius: 12px;
}

/* Base */
html, body {
    background: var(--bg-color);
    color: var(--text-1);
}

.container {
    width: min(1200px, 92%);
    margin: 0 auto;
}

/* Header & Navigation */
.site-header {
    position: sticky;
    top: 0;
    z-index: 1000;
    background: linear-gradient(180deg, rgba(14,15,19,0.95) 0%, rgba(14,15,19,0.85) 100%);
    backdrop-filter: blur(8px);
    border-bottom: 1px solid var(--border);
}

.primary-navigation .primary-menu li a {
    color: var(--text-2);
    position: relative;
    transition: color .2s ease;
}
.primary-navigation .primary-menu li a:hover,
.primary-navigation .primary-menu li.current-menu-item > a {
    color: var(--text-1);
}
.primary-navigation .primary-menu li a::after {
    content: '';
    position: absolute;
    left: 10px;
    right: 10px;
    bottom: 6px;
    height: 2px;
    background: var(--primary);
    transform: scaleX(0);
    transform-origin: left;
    transition: transform .25s ease;
}
.primary-navigation .primary-menu li a:hover::after,
.primary-navigation .primary-menu li.current-menu-item > a::after {
    transform: scaleX(1);
}

/* Buttons */
.button, .login-btn, .server-btn, .filter-button, .save-button,
#export-watchlist-btn, #import-watchlist-form button, .mark-as-read {
    background: var(--primary);
    color: #fff;
    border: 0;
    padding: 10px 14px;
    border-radius: 10px;
    box-shadow: var(--shadow);
    transition: transform .12s ease, background .2s ease, box-shadow .2s ease;
}
.button:hover, .login-btn:hover, .server-btn:hover, .filter-button:hover, .save-button:hover,
#export-watchlist-btn:hover, #import-watchlist-form button:hover, .mark-as-read:hover {
    background: var(--primary-600);
    transform: translateY(-1px);
}
.button:active, .login-btn:active, .server-btn:active, .filter-button:active {
    transform: translateY(0);
}

/* Forms */
input[type="text"], input[type="email"], input[type="password"], input[type="search"], input[type="file"], select, textarea {
    background: var(--surface-2);
    border: 1px solid var(--border);
    color: var(--text-1);
    padding: 10px 12px;
    border-radius: 10px;
    outline: none;
    transition: border .2s ease, box-shadow .2s ease;
}
input[type="text"]:focus, input[type="email"]:focus, input[type="password"]:focus, input[type="search"]:focus, select:focus, textarea:focus {
    border-color: var(--accent);
    box-shadow: 0 0 0 3px rgba(108,161,255,0.15);
}
label { color: var(--text-2); }

/* Archive Cards */
.archive-container {
    display: grid !important;
    grid-template-columns: repeat( auto-fill, minmax(160px, 1fr) );
    gap: 16px !important;
    padding: 24px 0 !important;
}
.archive-item {
    background: var(--surface-2) !important;
    border: 1px solid var(--border) !important;
    border-radius: var(--radius) !important;
    overflow: hidden !important;
    box-shadow: var(--shadow);
    transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}
.archive-item:hover {
    transform: translateY(-4px);
    border-color: rgba(108,161,255,0.35);
}
.archive-thumbnail {
    height: 240px !important;
    background: var(--surface-3);
}
.fixed-size-image {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}
.archive-title-main {
    padding: 10px 10px 14px !important;
}
.archive-title {
    color: var(--text-1) !important;
    font-size: 14px !important;
    line-height: 1.35;
}
.archive-category {
    background: linear-gradient(135deg, var(--primary), var(--primary-700)) !important;
    border-radius: 8px !important;
    padding: 4px 8px !important;
}
.post-meta {
    left: 10px !important;
    bottom: 10px !important;
    border-radius: 8px !important;
    background: rgba(0,0,0,.45) !important;
}

/* Hover panel */
.archive-hover {
    left: 100% !important;
    width: 300px !important;
    background: var(--surface-3) !important;
    border: 1px solid var(--border) !important;
}
.archive-hover-content .archive-hover-title { color: var(--text-1); }
.archive-hover .archive-buttons .btn-watch {
    background: var(--success);
}
.archive-hover .archive-buttons .btn-watchlist {
    background: var(--surface-2);
    border: 1px solid var(--border);
    color: var(--text-1);
}

/* Video Player Section */
.video-area { background: transparent; }
.video-player iframe {
    border: 1px solid var(--border);
    background: #000;
    border-radius: 14px !important;
}
.video-servers { gap: 12px !important; }
.server-btn { background: var(--surface-2); border: 1px solid var(--border); color: var(--text-1); }
.server-btn:hover { background: var(--surface-3); }

/* Profile / Tabs */
.profile-page { background: var(--surface-1); border: 1px solid var(--border); border-radius: var(--radius); box-shadow: var(--shadow); }
.profile-tabs ul { background: var(--surface-2) !important; border: 1px solid var(--border); height: auto !important; }
.profile-tabs li { color: var(--text-2) !important; }
.profile-tabs li.active { background: var(--surface-3) !important; color: var(--text-1) !important; border: 1px solid var(--border) !important; }
.tab { color: var(--text-2); }
.tab.active { color: var(--primary); }

/* Forms on profile */
.profile-content form input[type="email"],
.profile-content form input[type="text"],
.profile-content form input[type="file"],
.profile-content form input[type="password"] {
    width: min(520px, 100%) !important;
    background: var(--surface-2);
    border: 1px solid var(--border);
    color: var(--text-1);
}
.profile-content form button {
    width: min(520px, 100%) !important;
    background: var(--primary);
}

/* Watchlist */

/* =========================
   Mobile Responsive Enhancements
   ========================= */

/* Base container adjustments */
.container { max-width: 100%; padding: 0 12px; }

/* Shared grid layout used by pages */
/* .layout-grid { display: grid; grid-template-columns: 3fr 1fr; gap: 22px; } */

/* Navigation: show toggle on mobile and collapse menu */
.menu-toggle { display: none; background: var(--surface-2); border: 1px solid var(--border); border-radius: 10px; color: var(--text-1); padding: 8px 12px; }
.primary-navigation.open .primary-menu { display: flex; }

/* Video: use aspect ratio for iframes */
.video-player iframe { width: 100%; height: auto; aspect-ratio: 16 / 9; }

/* Archive cards grid tighten for small screens */
.archive-container { grid-template-columns: repeat( auto-fill, minmax(150px, 1fr) ); }

/* Breakpoint: tablets and below */
@media (max-width: 1024px) {
  .layout-grid { grid-template-columns: 2fr 1fr; gap: 18px; }
}

/* Breakpoint: mobile */
@media (max-width: 768px) {
  .layout-grid { grid-template-columns: 1fr !important; gap: 14px; }

  /* Header / Navigation */
  .menu-toggle { display: inline-flex; align-items: center; gap: 8px; }
  .primary-navigation { position: relative; }
  .primary-navigation .primary-menu { display: none; flex-direction: column; gap: 6px; background: var(--surface-2); border: 1px solid var(--border); border-radius: 10px; padding: 8px; position: static; }
  .primary-navigation .primary-menu li a { padding: 10px 12px; }
  .primary-navigation.open .primary-menu { display: flex; }

  /* Submenus stack in flow instead of absolute */
  .nav-menu .sub-menu, .sub-menu { position: static; display: none; background: var(--surface-2); border: 1px solid var(--border); border-radius: 10px; }
  .nav-menu .menu-item-has-children:hover .sub-menu { display: none; }

  /* Header buttons compact */
  .header-buttons { display: none; }

  /* Archive grid tighter */
  .archive-container { grid-template-columns: repeat( auto-fill, minmax(130px, 1fr) ); gap: 12px; }
  .archive-item { border-radius: 10px; }
  .archive-thumbnail { height: 180px; }

  /* Forms/buttons 
  tighter padding for mobile */
  .button, .login-btn, .server-btn, .filter-button, .save-button,
  #export-watchlist-btn, #import-watchlist-form button, .mark-as-read {
    padding: 10px 12px;
  }

  /* Profile */
  .profile-page { padding: 10px; }
  .profile-tabs ul { height: auto !important; }
}

/* Breakpoint: small mobile */
@media (max-width: 480px) {
  .archive-thumbnail { height: 160px; }
  .fixed-size-image { object-position: center; }
  .profile-content form button { width: 100% !important; }
}
.posts-list { gap: 12px; }
.post-item { background: var(--surface-2); border: 1px solid var(--border); border-radius: 12px; padding: 10px; width: 100%; max-width: 260px; }
.post-item img { border-radius: 8px; }
.change-status { background: var(--surface-1); border: 1px solid var(--border); color: var(--text-1); }

/* Search Bar */
.search-bar .search-form { background: var(--surface-2); padding: 10px; border: 1px solid var(--border); border-radius: 12px; }
.search-bar .search-submit { background: var(--primary); border-radius: 10px; }

/* Footer */
.site-footer { background: var(--surface-1); border-top: 1px solid var(--border); }
.site-footer .container { color: var(--text-3); }

/* Modal */
.modal-overlay { background: rgba(0,0,0,0.6) !important; }
.modal-box { background: var(--surface-2) !important; border: 1px solid var(--border) !important; border-radius: 14px; box-shadow: var(--shadow); }
.modal-close { background: var(--danger) !important; }

/* Text truncation utilities */
.truncate-1 { white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.truncate-2 { display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }

/* Ensure card titles do not overflow */
.archive-title { white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }

/* Responsive */
@media (max-width: 1024px) {
    .archive-container { grid-template-columns: repeat( auto-fill, minmax(150px, 1fr) ); }
}
@media (max-width: 768px) {
    .primary-navigation { display: none; }
    .archive-container { grid-template-columns: repeat( auto-fill, minmax(140px, 1fr) ); }
    .video-player iframe { height: 240px; }
}
