/* BasedApp Theme */
:root {
       --bg-color: #0d0d0d;
       --surface-color: #161616;
       --border-color: #333333;
       --primary-color: #0052FF;
       --primary-hover: #0040cc;
       --text-color: #ffffff;
       --text-secondary: #888888;
       --danger-color: #ff3b30;
       --font-family: 'Inter', system-ui, -apple-system, sans-serif;
}

* {
       box-sizing: border-box;
}

body {
       font-family: var(--font-family);
       background-color: var(--bg-color);
       margin: 0;
       display: flex;
       align-items: center;
       justify-content: center;
       min-height: 100vh;
       color: var(--text-color);
       overflow-x: hidden;
       overflow-y: auto;
       user-select: none;
       -webkit-user-select: none;
}

/* Layout */
.app-container {
       display: flex;
       flex-direction: column;
       gap: 20px;
       align-items: center;
       width: 100%;
       max-width: 1000px;
       position: relative;
       z-index: 10;
}

.header-title {
       display: flex;
       align-items: center;
       justify-content: center;
       gap: 15px;
       margin-bottom: 20px;
}

.header-title img {
       height: 60px;
       display: block;
       margin: 0;
}

.header-title p {
       margin: 0;
       font-size: 1rem;
       color: var(--text-color);
       text-transform: uppercase;
       letter-spacing: 4px;
       font-weight: 600;
       text-align: left;
}

.editor-wrapper {
       display: flex;
       gap: 20px;
       background-color: var(--surface-color);
       padding: 20px;
       border-radius: 16px;
       border: 1px solid var(--border-color);
       box-shadow: 0 20px 40px rgba(0, 0, 0, 0.4);
}

/* Canvas Area */
.canvas-area {
       width: 500px;
       height: 500px;
       position: relative;
       background-color: #000;
       border: 1px solid var(--border-color);
       border-radius: 8px;
       overflow: hidden;
}

.canvas-container {
       margin: 0 auto;
       user-select: none;
}

/* Sidebar */
.sidebar {
       width: 180px;
       height: 500px;
       background-color: var(--bg-color);
       border: 1px solid var(--border-color);
       border-radius: 8px;
       display: flex;
       flex-direction: column;
       padding: 15px;
       box-sizing: border-box;
}

.sidebar h2 {
       margin-top: 0;
       font-size: 0.9rem;
       text-transform: uppercase;
       color: var(--text-secondary);
       border-bottom: 1px solid var(--border-color);
       padding-bottom: 10px;
       letter-spacing: 1px;
}

.template-list {
       flex: 1;
       overflow: hidden;
       display: flex;
       flex-direction: column;
       gap: 10px;
       align-items: center;
       justify-content: flex-start;
       padding: 10px 0;
       width: 100%;
}

.template-item {
       cursor: pointer;
       border: 1px solid transparent;
       border-radius: 6px;
       padding: 5px;
       transition: all 0.2s;
       background-color: var(--surface-color);
       width: 100%;
       height: 72px;
       flex: 0 0 auto;
       display: flex;
       align-items: center;
       justify-content: center;
}

@media (hover: hover) {
       .template-item:hover {
              border-color: var(--primary-color);
              background-color: rgba(0, 82, 255, 0.1);
              transform: scale(0.95);
       }
}

.template-item.disabled {
       opacity: 0.4;
       cursor: not-allowed;
       pointer-events: none;
}

.template-item img {
       width: 100%;
       height: 100%;
       object-fit: contain;
       pointer-events: none;
}

/* Controls Bar */
.controls-bar {
       display: flex;
       gap: 15px;
       align-items: center;
       background-color: var(--surface-color);
       padding: 15px 25px;
       border-radius: 12px;
       border: 1px solid var(--border-color);
       width: 100%;
       box-sizing: border-box;
       max-width: 740px;
}

.divider {
       width: 1px;
       height: 24px;
       background-color: var(--border-color);
}

/* Buttons & Inputs */
button,
.file-upload-label {
       font-family: var(--font-family);
       font-weight: 600;
       text-transform: uppercase;
       letter-spacing: 0.5px;
       font-size: 0.85rem;
       cursor: pointer;
       transition: all 0.2s;
       border-radius: 6px;
}

.file-upload-label {
       display: inline-block;
       padding: 8px 16px;
       background-color: var(--surface-color);
       color: var(--text-color);
       border: 1px solid var(--border-color);
}

.file-upload-label:hover {
       border-color: var(--primary-color);
       color: var(--primary-color);
}

input[type="file"] {
       display: none;
}

/* Primary Buttons */
#export-btn {
       background-color: var(--primary-color);
       color: white;
       border: none;
       padding: 10px 20px;
       box-shadow: 0 4px 12px rgba(0, 82, 255, 0.3);
       border-radius: 6px;
       font-size: 1rem;
       cursor: pointer;
       transition: background 0.2s;
       touch-action: manipulation;
       -webkit-tap-highlight-color: transparent;
       user-select: none;
}

#export-btn:hover {
       background-color: var(--primary-hover);
       transform: translateY(-1px);
       box-shadow: 0 6px 16px rgba(0, 82, 255, 0.4);
}

#export-btn:disabled {
       background-color: var(--border-color);
       color: var(--text-secondary);
       cursor: not-allowed;
       box-shadow: none;
       transform: none;
       opacity: 0.5;
}



/* Secondary/Danger Buttons */
#reset-btn {
       background-color: transparent;
       color: var(--text-secondary);
       border: 1px solid transparent;
       padding: 8px 16px;
}

#reset-btn:hover {
       color: var(--danger-color);
       background-color: rgba(255, 59, 48, 0.1);
}

/* Sliders */
.zoom-control {
       display: flex;
       align-items: center;
       gap: 10px;
       color: var(--text-secondary);
       font-size: 0.85rem;
       text-transform: uppercase;
}

input[type=range] {
       -webkit-appearance: none;
       appearance: none;
       background: transparent;
}

input[type=range]::-webkit-slider-thumb {
       -webkit-appearance: none;
       height: 16px;
       width: 16px;
       border-radius: 50%;
       background: var(--text-color);
       cursor: pointer;
       margin-top: -6px;
       box-shadow: 0 2px 6px rgba(0, 0, 0, 0.5);
}

input[type=range]::-webkit-slider-runnable-track {
       width: 100%;
       height: 4px;
       cursor: pointer;
       background: var(--border-color);
       border-radius: 2px;
}

/* Fabric.js Overrides */
.canvas-container {
       border-radius: 8px;
       overflow: hidden;
}

/* Empty State */
.empty-state {
       position: absolute;
       top: 50%;
       left: 50%;
       transform: translate(-50%, -50%);
       text-align: center;
       color: var(--text-secondary);
       width: 100%;
       height: 100%;
       display: flex;
       align-items: center;
       justify-content: center;
       font-weight: 500;
       letter-spacing: 0.5px;
       cursor: pointer;
       z-index: 5;
}

.empty-state:hover {
       background-color: rgba(255, 255, 255, 0.03);
       color: var(--text-color);
}


/* Background Orbs */
.orb {
       position: fixed;
       z-index: 0;
       pointer-events: none;
       width: 800px;
       height: auto;
       opacity: 0.6;
       filter: blur(80px);
}

.orb-red {
       width: 700px;
       top: -150px;
       left: -350px;
}

.orb-green {
       top: 50%;
       right: -300px;
       transform: translateY(-50%);
}

/* Responsive */
@media (max-width: 900px) {
       body {
              align-items: flex-start;
              padding-top: 20px;
              padding-bottom: 20px;
              height: auto;
       }

       .app-container {
              width: 100%;
              max-width: 100%;
              padding: 10px;
       }

       .editor-wrapper {
              flex-direction: column;
              align-items: center;
              width: 100%;
              padding: 10px;
              gap: 15px;
       }

       .canvas-area {
              transform-origin: top center;
              margin-bottom: 0;
       }


       .sidebar {
              width: 100%;
              height: auto;
              flex-direction: column;
              padding: 10px;
       }

       .sidebar h2 {
              text-align: center;
              border-bottom: none;
              margin-bottom: 5px;
       }

       .template-list {
              flex: 0 0 auto;
              flex-direction: row;
              flex-wrap: nowrap;
              overflow-x: auto;
              overflow-y: hidden;
              justify-content: center;
              padding: 0 10px;
              gap: 10px;
              height: 80px;
              width: 100%;
              -webkit-overflow-scrolling: touch;
              align-items: center;
              position: relative;
              z-index: 50;
       }

       .template-item {
              width: 56px;
              min-width: 56px;
              height: 56px;
              min-height: 56px;
              flex: 0 0 56px;
              display: flex;
              align-items: center;
              justify-content: center;
              background-color: var(--surface-color);
       }

       .controls-bar {
              flex-wrap: wrap;
              justify-content: center;
              gap: 10px;
       }

       .header-title h1 {
              font-size: 3rem;
       }

       .header-title img {
              height: 40px;
       }

       .header-title p {
              font-size: 0.9rem;
       }

       .empty-state {
              pointer-events: none;
              cursor: default;
       }

       /* Scale orbs for mobile */
       .orb-red {
              width: 350px;
              top: -80px;
              left: -100px;
       }

       .orb-green {
              width: 400px;
              right: -150px;
       }
}

/* Footer */
.footer {
       margin-top: 20px;
       font-size: 0.8rem;
       color: var(--text-secondary);
       text-align: center;
       text-transform: uppercase;
       letter-spacing: 1px;
}

.footer a {
       color: var(--text-color);
       text-decoration: none;
       font-weight: 600;
       border-bottom: 1px solid transparent;
       transition: all 0.2s;
}

.footer a:hover {
       color: var(--primary-color);
       border-bottom-color: var(--primary-color);
}

.footer .separator {
       margin: 0 10px;
       opacity: 0.5;
       color: var(--border-color);
}

#pfp-counter {
       font-weight: 600;
       color: var(--text-color);
}