/*
Theme Name: SeeMeNow Theme
Theme URI: https://seemenow.ai
Author: SeeMe Now
Description: Custom theme for SeeMe Now app. No page builders. No bloat. Just the plugin.
Version: 2.0.0
Requires at least: 6.0
Tested up to: 6.7
Requires PHP: 8.0
License: Proprietary
*/

/* =========================================
   FONTS
   ========================================= */

@import url('https://fonts.googleapis.com/css2?family=DM+Sans:ital,opsz,wght@0,9..40,300;0,9..40,400;0,9..40,500;0,9..40,600;0,9..40,700;1,9..40,400&family=DM+Mono:wght@400;500&display=swap');

/* =========================================
   CSS VARIABLES — DARK MODE (DEFAULT)
   ========================================= */

:root {
    --smw-accent:        #7c6af7;
    --smw-accent-2:      #9f5cf6;
    --smw-accent-grad:   linear-gradient(135deg, #667eea 0%, #764ba2 100%);
    --smw-accent-glow:   rgba(124, 106, 247, 0.25);
    --smw-accent-subtle: rgba(124, 106, 247, 0.1);

    --smw-sb-bg:         #0f0f1a;
    --smw-sb-bg-2:       #16162a;
    --smw-sb-border:     rgba(255, 255, 255, 0.06);
    --smw-sb-text:       #8b8fa8;
    --smw-sb-text-muted: #4a4d66;
    --smw-sb-text-on:    #c4b5fd;
    --smw-sb-hover-bg:   rgba(255, 255, 255, 0.05);
    --smw-sb-active-bg:  rgba(124, 106, 247, 0.14);
    --smw-sb-width:      248px;
    --smw-sb-width-col:  60px;

    --smw-bg:            #0d0d1a;
    --smw-bg-2:          #12121f;
    --smw-bg-card:       #1a1a2e;
    --smw-text:          #e2e4f0;
    --smw-text-muted:    #6b6f8a;
    --smw-border:        rgba(255, 255, 255, 0.07);
    --smw-border-2:      rgba(255, 255, 255, 0.04);

    --smw-shadow-sm:     0 1px 3px rgba(0,0,0,0.4);
    --smw-shadow-md:     0 4px 16px rgba(0,0,0,0.5);
    --smw-shadow-lg:     0 12px 40px rgba(0,0,0,0.6);

    --smw-r-sm:   6px;
    --smw-r-md:   10px;
    --smw-r-lg:   14px;
    --smw-r-xl:   20px;

    --smw-font:   'DM Sans', -apple-system, BlinkMacSystemFont, sans-serif;
    --smw-mono:   'DM Mono', 'Fira Code', monospace;

    --smw-t:      0.15s ease;
    --smw-t-slow: 0.25s ease;
}

/* =========================================
   LIGHT MODE
   ========================================= */

[data-smw-theme="light"] {
    --smw-sb-bg:         #1a1a2e;
    --smw-sb-bg-2:       #21213a;
    --smw-sb-border:     rgba(255, 255, 255, 0.07);
    --smw-sb-text:       #9ca3c8;
    --smw-sb-text-muted: #5a5e7a;
    --smw-sb-text-on:    #c4b5fd;
    --smw-sb-hover-bg:   rgba(255, 255, 255, 0.06);
    --smw-sb-active-bg:  rgba(124, 106, 247, 0.18);

    --smw-bg:            #f4f5fb;
    --smw-bg-2:          #eeeef8;
    --smw-bg-card:       #ffffff;
    --smw-text:          #1a1b2e;
    --smw-text-muted:    #6b6f8a;
    --smw-border:        rgba(0, 0, 0, 0.08);
    --smw-border-2:      rgba(0, 0, 0, 0.04);

    --smw-shadow-sm:     0 1px 3px rgba(0,0,0,0.08);
    --smw-shadow-md:     0 4px 16px rgba(0,0,0,0.1);
    --smw-shadow-lg:     0 12px 40px rgba(0,0,0,0.15);
}

/* =========================================
   RESET & BASE
   ========================================= */

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

html { font-size: 15px; -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }

body {
    font-family: var(--smw-font);
    font-size: 14px;
    line-height: 1.6;
    color: var(--smw-text);
    background: var(--smw-bg);
    min-height: 100vh;
    transition: background var(--smw-t-slow), color var(--smw-t-slow);
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

a { color: inherit; text-decoration: none; }
img { max-width: 100%; height: auto; display: block; }
button { font-family: var(--smw-font); cursor: pointer; border: none; background: none; }

/* =========================================
   APP LAYOUT
   ========================================= */

body.smw-has-sidebar { margin-left: var(--smw-sb-width); transition: margin-left var(--smw-t-slow); }
body.smw-has-sidebar.smw-sb-col { margin-left: var(--smw-sb-width-col); }
#smw-main { min-height: 100vh; width: 100%; }
.smw-page-content { width: 100%; min-height: 100vh; }

/* =========================================
   BARE PAGES — login, signup
   ========================================= */

body.smw-bare-page {
    background: var(--smw-bg);
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 100vh;
    padding: 20px;
    position: relative;
    overflow: hidden;
}

body.smw-bare-page::before {
    content: '';
    position: fixed;
    inset: 0;
    background-image:
        linear-gradient(rgba(124,106,247,0.04) 1px, transparent 1px),
        linear-gradient(90deg, rgba(124,106,247,0.04) 1px, transparent 1px);
    background-size: 40px 40px;
    pointer-events: none;
}

body.smw-bare-page::after {
    content: '';
    position: fixed;
    top: -30%;
    left: -10%;
    width: 60%;
    height: 60%;
    background: radial-gradient(ellipse, rgba(124,106,247,0.1) 0%, transparent 70%);
    pointer-events: none;
}

body.smw-bare-page #smw-main {
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
    z-index: 1;
}

/* =========================================
   THEME TOGGLE BUTTON
   ========================================= */

#smw-theme-toggle {
    position: fixed;
    bottom: 20px;
    right: 20px;
    width: 38px;
    height: 38px;
    border-radius: 50%;
    background: var(--smw-bg-card);
    border: 1px solid var(--smw-border);
    color: var(--smw-text-muted);
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    z-index: 99998;
    box-shadow: var(--smw-shadow-md);
    transition: all var(--smw-t);
    font-size: 15px;
    line-height: 1;
}

#smw-theme-toggle:hover {
    border-color: var(--smw-accent);
    color: var(--smw-accent);
    transform: scale(1.08);
    box-shadow: 0 0 0 3px var(--smw-accent-glow), var(--smw-shadow-md);
}

/* =========================================
   WP CLEANUP
   ========================================= */

.wp-site-blocks, .wp-block-template-part { all: unset; }
.site-header, .site-footer, .site-branding, .main-navigation,
.widget-area, .comments-area, .post-navigation, .entry-footer { display: none !important; }

body.admin-bar #smw-main { margin-top: 32px; }
@media screen and (max-width: 782px) { body.admin-bar #smw-main { margin-top: 46px; } }

/* =========================================
   SIDEBAR VISUAL UPGRADES
   ========================================= */

.smw-sidebar {
    background: var(--smw-sb-bg) !important;
    border-right: 1px solid var(--smw-sb-border) !important;
    font-family: var(--smw-font) !important;
    width: var(--smw-sb-width) !important;
    box-shadow: 4px 0 24px rgba(0,0,0,0.4) !important;
}

.smw-sidebar--collapsed { width: var(--smw-sb-width-col) !important; }
body.smw-has-sidebar { margin-left: var(--smw-sb-width) !important; }
body.smw-has-sidebar.smw-sb-col { margin-left: var(--smw-sb-width-col) !important; }

/* Logo strip */
.smw-sb-logo {
    display: flex;
    align-items: center;
    height: 56px;
    padding: 0 16px;
    border-bottom: 1px solid var(--smw-sb-border);
    flex-shrink: 0;
    gap: 10px;
}

.smw-sb-logo-mark {
    width: 28px;
    height: 28px;
    border-radius: 8px;
    background: var(--smw-accent-grad);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 13px;
    font-weight: 800;
    color: #fff;
    flex-shrink: 0;
    box-shadow: 0 4px 12px rgba(124,106,247,0.4);
}

.smw-sb-logo-text {
    font-size: 14px;
    font-weight: 700;
    color: #fff;
    letter-spacing: -0.3px;
    white-space: nowrap;
}

.smw-sidebar--collapsed .smw-sb-logo-text { display: none; }

/* Project switcher */
.smw-sb-project { border-bottom: 1px solid var(--smw-sb-border) !important; padding: 10px 8px !important; }

.smw-sb-project-current {
    background: rgba(255,255,255,0.04) !important;
    border-radius: var(--smw-r-md) !important;
    border: 1px solid var(--smw-sb-border) !important;
    transition: all var(--smw-t) !important;
}

.smw-sb-project-current:hover {
    background: rgba(124,106,247,0.08) !important;
    border-color: rgba(124,106,247,0.2) !important;
}

.smw-sb-proj-lbl {
    color: var(--smw-sb-text-muted) !important;
    font-size: 9px !important;
    letter-spacing: 0.8px !important;
    font-weight: 700 !important;
}

.smw-sb-proj-name { color: #fff !important; font-size: 13px !important; font-weight: 600 !important; }

.smw-sb-proj-dropdown {
    background: var(--smw-sb-bg-2) !important;
    border: 1px solid var(--smw-sb-border) !important;
    border-radius: var(--smw-r-md) !important;
    box-shadow: var(--smw-shadow-md) !important;
}

.smw-sb-proj-item { color: var(--smw-sb-text) !important; font-size: 12.5px !important; border-radius: var(--smw-r-sm) !important; font-weight: 500 !important; }
.smw-sb-proj-item:hover { background: var(--smw-sb-hover-bg) !important; color: #fff !important; }
.smw-sb-proj-item--on { background: var(--smw-sb-active-bg) !important; color: var(--smw-sb-text-on) !important; }
.smw-sb-proj-dot { background: var(--smw-sb-text-muted) !important; }
.smw-sb-proj-item--on .smw-sb-proj-dot { background: var(--smw-accent) !important; }

/* Nav */
.smw-sb-nav { padding: 8px 8px !important; gap: 2px !important; }

.smw-sb-i {
    color: var(--smw-sb-text) !important;
    font-size: 13px !important;
    font-weight: 500 !important;
    padding: 8px 12px !important;
    border-radius: var(--smw-r-sm) !important;
    transition: all var(--smw-t) !important;
    letter-spacing: -0.1px !important;
}

.smw-sb-i:hover { background: var(--smw-sb-hover-bg) !important; color: #e8eaf6 !important; }
.smw-sb-i--on { background: var(--smw-sb-active-bg) !important; color: var(--smw-sb-text-on) !important; }
.smw-sb-i--on::before { background: var(--smw-accent) !important; border-radius: 0 3px 3px 0 !important; }
.smw-sb-i-icon { font-size: 15px !important; width: 20px !important; }

/* Submenus */
.smw-sb-sub-hd { color: var(--smw-sb-text-muted) !important; font-size: 9px !important; letter-spacing: 0.8px !important; font-weight: 700 !important; padding-left: 44px !important; }
.smw-sb-sub-a { color: var(--smw-sb-text) !important; font-size: 12.5px !important; font-weight: 500 !important; padding: 6px 10px 6px 44px !important; border-radius: var(--smw-r-sm) !important; }
.smw-sb-sub-a:hover { background: var(--smw-sb-hover-bg) !important; color: #e8eaf6 !important; }
.smw-sb-sub-a--on { background: var(--smw-sb-active-bg) !important; color: var(--smw-sb-text-on) !important; font-weight: 600 !important; }

.smw-sb-sub-g-trigger { color: var(--smw-sb-text-muted) !important; font-size: 9px !important; letter-spacing: 0.8px !important; font-weight: 700 !important; padding: 8px 10px 4px 12px !important; border-radius: var(--smw-r-sm) !important; }
.smw-sb-sub-g-trigger:hover { background: var(--smw-sb-hover-bg) !important; color: var(--smw-sb-text) !important; }
.smw-sb-sub-g--open .smw-sb-sub-g-trigger { color: var(--smw-sb-text-on) !important; }
.smw-sb-sub-g-items .smw-sb-sub-a { padding-left: 56px !important; }

/* Footer */
.smw-sb-footer { border-top: 1px solid var(--smw-sb-border) !important; padding: 8px 8px !important; }

.smw-sb-newproj {
    background: var(--smw-sb-active-bg) !important;
    border: 1px dashed rgba(124,106,247,0.3) !important;
    border-radius: var(--smw-r-md) !important;
    color: var(--smw-sb-text-on) !important;
    font-size: 12.5px !important;
    font-weight: 600 !important;
    padding: 8px 12px !important;
    transition: all var(--smw-t) !important;
}

.smw-sb-newproj:hover {
    background: rgba(124,106,247,0.2) !important;
    border-color: rgba(124,106,247,0.5) !important;
    transform: translateY(-1px) !important;
    box-shadow: 0 4px 12px rgba(124,106,247,0.2) !important;
}

.smw-sb-account-group { border-top: 1px solid var(--smw-sb-border) !important; }

/* Toggle */
.smw-sb-toggle {
    background: var(--smw-sb-bg) !important;
    border: 1px solid var(--smw-sb-border) !important;
    color: var(--smw-sb-text) !important;
    box-shadow: var(--smw-shadow-sm) !important;
    right: -13px !important;
    top: 72px !important;
    transition: all var(--smw-t) !important;
}

.smw-sb-toggle:hover {
    background: var(--smw-sb-bg-2) !important;
    border-color: var(--smw-accent) !important;
    color: var(--smw-accent) !important;
}

/* Collapsed tooltip */
.smw-sidebar--collapsed .smw-sb-i:hover::after {
    background: var(--smw-sb-bg-2) !important;
    border: 1px solid var(--smw-sb-border) !important;
    box-shadow: var(--smw-shadow-md) !important;
    font-family: var(--smw-font) !important;
    font-size: 12px !important;
    font-weight: 600 !important;
    border-radius: var(--smw-r-sm) !important;
    color: #e8eaf6 !important;
}

body.admin-bar .smw-sidebar { top: 32px !important; }
@media (max-width: 782px) { body.admin-bar .smw-sidebar { top: 46px !important; } }
@media (max-width: 768px) {
    .smw-sidebar { width: var(--smw-sb-width-col) !important; }
    body.smw-has-sidebar { margin-left: var(--smw-sb-width-col) !important; }
    .smw-sb-toggle { display: none !important; }
}

/* =========================================
   GLOBAL ELEMENT UPGRADES
   ========================================= */

.smw-card, .smw-panel, .smw-section, .smw-box {
    background: var(--smw-bg-card);
    border: 1px solid var(--smw-border);
    border-radius: var(--smw-r-lg);
    box-shadow: var(--smw-shadow-sm);
}

.smw-table-wrapper {
    background: var(--smw-bg-card);
    border: 1px solid var(--smw-border);
    border-radius: var(--smw-r-lg);
    overflow: hidden;
}

.smw-btn, .smw-button {
    font-family: var(--smw-font) !important;
    font-weight: 600 !important;
    border-radius: var(--smw-r-sm) !important;
    transition: all var(--smw-t) !important;
}

input[type="text"], input[type="email"], input[type="password"],
input[type="url"], input[type="date"], input[type="number"],
select, textarea {
    font-family: var(--smw-font) !important;
    background: var(--smw-bg-2) !important;
    border: 1px solid var(--smw-border) !important;
    color: var(--smw-text) !important;
    border-radius: var(--smw-r-sm) !important;
    transition: border-color var(--smw-t) !important;
}

input[type="text"]:focus, input[type="email"]:focus, input[type="password"]:focus,
input[type="url"]:focus, input[type="date"]:focus, input[type="number"]:focus,
select:focus, textarea:focus {
    outline: none !important;
    border-color: var(--smw-accent) !important;
    box-shadow: 0 0 0 3px var(--smw-accent-glow) !important;
}

/* Scrollbars */
* { scrollbar-width: thin; scrollbar-color: rgba(124,106,247,0.2) transparent; }
*::-webkit-scrollbar { width: 5px; height: 5px; }
*::-webkit-scrollbar-track { background: transparent; }
*::-webkit-scrollbar-thumb { background: rgba(124,106,247,0.2); border-radius: 10px; }
*::-webkit-scrollbar-thumb:hover { background: rgba(124,106,247,0.4); }

/* Print */
@media print {
    body.smw-has-sidebar { margin-left: 0; }
    .smw-sidebar, #smw-theme-toggle { display: none; }
}

/* =========================================
   LOGO IMAGE OVERRIDE
   ========================================= */

.smw-sb-logo-mark {
    background: transparent !important;
    box-shadow: none !important;
    padding: 0 !important;
    width: 30px !important;
    height: 30px !important;
    border-radius: 6px !important;
    overflow: hidden !important;
    flex-shrink: 0 !important;
}

.smw-sb-logo-mark img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    display: block !important;
    border-radius: 6px !important;
}
