| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| |
|
| | :root { |
| | --miami-red: #C41230; |
| | --miami-light-tan: #EDECE2; |
| | --miami-medium-tan: #CCC9B8; |
| | --miami-yellow: #EFDB72; |
| | --miami-white: #FFFFFF; |
| | --miami-black: #000000; |
| | --miami-dark-red: #9E0F28; |
| | } |
| |
|
| | |
| | body { |
| | background-color: var(--miami-light-tan); |
| | font-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif; |
| | color: var(--miami-black); |
| | } |
| |
|
| | |
| | .app-header { |
| | background: linear-gradient(135deg, var(--miami-red) 0%, var(--miami-dark-red) 100%); |
| | color: var(--miami-white); |
| | padding: 20px 30px; |
| | margin: -15px -15px 20px -15px; |
| | border-radius: 0; |
| | box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15); |
| | } |
| |
|
| | .app-header h1 { |
| | margin: 0 0 5px 0; |
| | font-size: 1.8em; |
| | font-weight: 600; |
| | letter-spacing: 0.5px; |
| | } |
| |
|
| | .app-header .subtitle { |
| | font-size: 0.9em; |
| | opacity: 0.9; |
| | margin: 0; |
| | } |
| |
|
| | .header-content { |
| | display: flex; |
| | justify-content: space-between; |
| | align-items: center; |
| | flex-wrap: wrap; |
| | gap: 20px; |
| | } |
| |
|
| | .header-left { |
| | flex: 1; |
| | min-width: 300px; |
| | } |
| |
|
| | .header-right { |
| | text-align: right; |
| | } |
| |
|
| | .header-right p { |
| | margin: 3px 0; |
| | font-size: 0.85em; |
| | } |
| |
|
| | |
| | .logo-container { |
| | display: flex; |
| | align-items: center; |
| | gap: 20px; |
| | background-color: var(--miami-white); |
| | padding: 15px 20px; |
| | border-radius: 8px; |
| | margin-bottom: 20px; |
| | box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08); |
| | } |
| |
|
| | .logo-container img { |
| | height: 50px; |
| | width: auto; |
| | object-fit: contain; |
| | } |
| |
|
| | .logo-divider { |
| | width: 1px; |
| | height: 40px; |
| | background-color: var(--miami-medium-tan); |
| | } |
| |
|
| | |
| | .shiny-title-panel { |
| | display: none; |
| | } |
| |
|
| | |
| | .well { |
| | background-color: var(--miami-white); |
| | border: 1px solid var(--miami-medium-tan); |
| | border-radius: 8px; |
| | box-shadow: 0 2px 8px rgba(0, 0, 0, 0.06); |
| | padding: 20px; |
| | } |
| |
|
| | |
| | .sidebar-panel { |
| | background-color: var(--miami-white); |
| | border: 1px solid var(--miami-medium-tan); |
| | border-radius: 8px; |
| | box-shadow: 0 2px 8px rgba(0, 0, 0, 0.06); |
| | } |
| |
|
| | |
| | .main-panel { |
| | background-color: transparent; |
| | } |
| |
|
| | |
| | .info-card { |
| | background-color: var(--miami-white); |
| | border: 1px solid var(--miami-medium-tan); |
| | border-radius: 8px; |
| | padding: 20px; |
| | margin-bottom: 20px; |
| | box-shadow: 0 2px 8px rgba(0, 0, 0, 0.06); |
| | } |
| |
|
| | .info-card h4 { |
| | color: var(--miami-red); |
| | margin-top: 0; |
| | padding-bottom: 10px; |
| | border-bottom: 2px solid var(--miami-light-tan); |
| | font-weight: 600; |
| | } |
| |
|
| | |
| | .how-to-use { |
| | background-color: var(--miami-white); |
| | border-left: 4px solid var(--miami-red); |
| | border-radius: 0 8px 8px 0; |
| | padding: 20px; |
| | margin-bottom: 25px; |
| | } |
| |
|
| | .how-to-use h4 { |
| | color: var(--miami-red); |
| | margin-top: 0; |
| | font-weight: 600; |
| | } |
| |
|
| | .how-to-use ol { |
| | padding-left: 20px; |
| | } |
| |
|
| | .how-to-use li { |
| | margin-bottom: 8px; |
| | line-height: 1.5; |
| | } |
| |
|
| | |
| | .btn-video-tutorial { |
| | background-color: var(--miami-medium-tan); |
| | color: var(--miami-black); |
| | border: none; |
| | border-radius: 6px; |
| | padding: 8px 16px; |
| | font-weight: 500; |
| | cursor: pointer; |
| | transition: all 0.2s; |
| | } |
| |
|
| | .btn-video-tutorial:hover { |
| | background-color: var(--miami-yellow); |
| | color: var(--miami-black); |
| | } |
| |
|
| | |
| | .video-modal { |
| | display: none; |
| | position: fixed; |
| | z-index: 9999; |
| | left: 0; |
| | top: 0; |
| | width: 100%; |
| | height: 100%; |
| | background-color: rgba(0, 0, 0, 0.8); |
| | justify-content: center; |
| | align-items: center; |
| | } |
| |
|
| | .video-modal-content { |
| | background-color: var(--miami-white); |
| | border-radius: 12px; |
| | padding: 25px; |
| | width: 90%; |
| | max-width: 900px; |
| | position: relative; |
| | box-shadow: 0 8px 32px rgba(0, 0, 0, 0.3); |
| | } |
| |
|
| | .video-modal-close { |
| | position: absolute; |
| | top: 10px; |
| | right: 18px; |
| | font-size: 32px; |
| | font-weight: bold; |
| | color: var(--miami-medium-tan); |
| | cursor: pointer; |
| | transition: color 0.2s; |
| | line-height: 1; |
| | } |
| |
|
| | .video-modal-close:hover { |
| | color: var(--miami-red); |
| | } |
| |
|
| | .video-modal-wrapper { |
| | position: relative; |
| | padding-bottom: 56.25%; |
| | height: 0; |
| | overflow: hidden; |
| | border-radius: 8px; |
| | background-color: #000; |
| | } |
| |
|
| | .video-modal-wrapper iframe { |
| | position: absolute; |
| | top: 0; |
| | left: 0; |
| | width: 100%; |
| | height: 100%; |
| | border: none; |
| | } |
| |
|
| | |
| | .form-control { |
| | border: 1px solid var(--miami-medium-tan); |
| | border-radius: 6px; |
| | transition: border-color 0.2s, box-shadow 0.2s; |
| | } |
| |
|
| | .form-control:focus { |
| | border-color: var(--miami-red); |
| | box-shadow: 0 0 0 3px rgba(196, 18, 48, 0.15); |
| | outline: none; |
| | } |
| |
|
| | |
| | textarea.form-control { |
| | resize: vertical; |
| | min-height: 150px; |
| | } |
| |
|
| | |
| | .control-label { |
| | font-weight: 600; |
| | color: var(--miami-black); |
| | margin-bottom: 5px; |
| | } |
| |
|
| | |
| | .btn { |
| | border-radius: 6px; |
| | font-weight: 500; |
| | padding: 10px 20px; |
| | transition: all 0.2s; |
| | border: none; |
| | margin-right: 10px; |
| | margin-top: 10px; |
| | } |
| |
|
| | .btn-primary { |
| | background-color: var(--miami-red); |
| | color: var(--miami-white); |
| | } |
| |
|
| | .btn-primary:hover, |
| | .btn-primary:focus { |
| | background-color: var(--miami-dark-red); |
| | color: var(--miami-white); |
| | box-shadow: 0 4px 12px rgba(196, 18, 48, 0.3); |
| | } |
| |
|
| | .btn-info { |
| | background-color: var(--miami-medium-tan); |
| | color: var(--miami-black); |
| | } |
| |
|
| | .btn-info:hover, |
| | .btn-info:focus { |
| | background-color: var(--miami-yellow); |
| | color: var(--miami-black); |
| | } |
| |
|
| | |
| | .table { |
| | background-color: var(--miami-white); |
| | border-radius: 8px; |
| | overflow: hidden; |
| | box-shadow: 0 2px 8px rgba(0, 0, 0, 0.06); |
| | } |
| |
|
| | .table > thead > tr > th { |
| | background-color: var(--miami-red); |
| | color: var(--miami-white); |
| | font-weight: 600; |
| | border: none; |
| | padding: 12px 15px; |
| | } |
| |
|
| | .table > tbody > tr > td { |
| | padding: 12px 15px; |
| | border-color: var(--miami-light-tan); |
| | vertical-align: middle; |
| | } |
| |
|
| | .table > tbody > tr:nth-child(odd) { |
| | background-color: var(--miami-light-tan); |
| | } |
| |
|
| | .table > tbody > tr:nth-child(even) { |
| | background-color: var(--miami-white); |
| | } |
| |
|
| | .table > tbody > tr:hover { |
| | background-color: rgba(239, 219, 114, 0.3); |
| | } |
| |
|
| | |
| | hr { |
| | border-color: var(--miami-medium-tan); |
| | margin: 15px 0; |
| | } |
| |
|
| | |
| | .help-block { |
| | color: #666; |
| | font-size: 0.85em; |
| | font-style: italic; |
| | } |
| |
|
| | |
| | .tips-section { |
| | background-color: rgba(239, 219, 114, 0.2); |
| | border: 1px solid var(--miami-yellow); |
| | border-radius: 8px; |
| | padding: 20px; |
| | margin-top: 20px; |
| | } |
| |
|
| | .tips-section h4 { |
| | color: var(--miami-black); |
| | margin-top: 0; |
| | font-weight: 600; |
| | } |
| |
|
| | .tips-section ul { |
| | padding-left: 20px; |
| | margin-bottom: 0; |
| | } |
| |
|
| | .tips-section li { |
| | margin-bottom: 6px; |
| | line-height: 1.5; |
| | } |
| |
|
| | |
| | .note-section { |
| | background-color: var(--miami-white); |
| | border: 1px solid var(--miami-medium-tan); |
| | border-radius: 8px; |
| | padding: 15px 20px; |
| | margin-top: 20px; |
| | } |
| |
|
| | .note-section h4 { |
| | color: var(--miami-red); |
| | margin-top: 0; |
| | margin-bottom: 10px; |
| | font-weight: 600; |
| | } |
| |
|
| | |
| | .section-heading { |
| | color: var(--miami-red); |
| | font-weight: 600; |
| | padding-bottom: 10px; |
| | border-bottom: 2px solid var(--miami-light-tan); |
| | margin-bottom: 15px; |
| | } |
| |
|
| | |
| | .results-placeholder { |
| | color: #888; |
| | font-style: italic; |
| | padding: 20px; |
| | text-align: center; |
| | background-color: var(--miami-light-tan); |
| | border-radius: 6px; |
| | } |
| |
|
| | |
| | .field-separator { |
| | border-color: var(--miami-light-tan); |
| | margin: 20px 0; |
| | } |
| |
|
| | |
| | .shiny-notification { |
| | border-radius: 8px; |
| | border: none; |
| | box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15); |
| | } |
| |
|
| | .shiny-notification-message { |
| | background-color: var(--miami-red); |
| | color: var(--miami-white); |
| | } |
| |
|
| | .shiny-notification-error { |
| | background-color: #d32f2f; |
| | color: var(--miami-white); |
| | } |
| |
|
| | |
| | .app-footer { |
| | text-align: center; |
| | padding: 15px; |
| | margin-top: 30px; |
| | color: #666; |
| | font-size: 0.85em; |
| | border-top: 1px solid var(--miami-medium-tan); |
| | } |
| |
|
| | |
| | .input-tabs-container { |
| | margin-bottom: 15px; |
| | } |
| |
|
| | .input-tabs { |
| | display: flex; |
| | gap: 5px; |
| | margin-bottom: 5px; |
| | } |
| |
|
| | .input-tab { |
| | flex: 1; |
| | padding: 10px 15px; |
| | border: 1px solid var(--miami-medium-tan); |
| | background-color: var(--miami-light-tan); |
| | color: var(--miami-black); |
| | border-radius: 6px 6px 0 0; |
| | cursor: pointer; |
| | font-weight: 500; |
| | font-size: 0.9em; |
| | transition: all 0.2s; |
| | } |
| |
|
| | .input-tab:hover { |
| | background-color: var(--miami-medium-tan); |
| | } |
| |
|
| | .input-tab.active { |
| | background-color: var(--miami-red); |
| | color: var(--miami-white); |
| | border-color: var(--miami-red); |
| | } |
| |
|
| | .input-panel { |
| | border: 1px solid var(--miami-medium-tan); |
| | border-top: none; |
| | border-radius: 0 0 6px 6px; |
| | padding: 15px; |
| | background-color: var(--miami-white); |
| | margin-top: -1px; |
| | } |
| |
|
| | |
| | .pdf-preview { |
| | margin-top: 15px; |
| | padding: 10px; |
| | background-color: var(--miami-light-tan); |
| | border-radius: 6px; |
| | max-height: 200px; |
| | overflow-y: auto; |
| | } |
| |
|
| | .pdf-preview pre { |
| | margin: 5px 0 0 0; |
| | white-space: pre-wrap; |
| | word-wrap: break-word; |
| | font-size: 0.85em; |
| | max-height: 150px; |
| | overflow-y: auto; |
| | } |
| |
|
| | |
| | .input-panel .form-group { |
| | margin-bottom: 0; |
| | } |
| |
|
| | .input-panel .shiny-input-container { |
| | width: 100%; |
| | } |
| |
|
| | |
| | .input-panel .btn-file { |
| | background-color: var(--miami-red); |
| | color: var(--miami-white); |
| | border: none; |
| | border-radius: 6px; |
| | font-weight: 500; |
| | } |
| |
|
| | .input-panel .btn-file:hover, |
| | .input-panel .btn-file:focus { |
| | background-color: var(--miami-dark-red); |
| | color: var(--miami-white); |
| | } |
| |
|
| | |
| | .image-limit-note { |
| | background-color: rgba(239, 219, 114, 0.3); |
| | border: 1px solid var(--miami-yellow); |
| | border-radius: 4px; |
| | padding: 8px 12px; |
| | margin-top: 10px; |
| | font-size: 0.85em; |
| | color: #666; |
| | } |
| |
|
| | |
| | .file-format-note { |
| | background-color: var(--miami-light-tan); |
| | border-radius: 4px; |
| | padding: 10px 12px; |
| | margin-top: 10px; |
| | font-size: 0.9em; |
| | } |
| |
|
| | .file-format-note ul { |
| | color: #666; |
| | } |
| |
|
| |
|
| | |
| | .image-preview-grid { |
| | display: grid; |
| | grid-template-columns: repeat(auto-fill, minmax(80px, 1fr)); |
| | gap: 8px; |
| | margin-top: 10px; |
| | } |
| |
|
| | .image-preview-item { |
| | border: 1px solid var(--miami-medium-tan); |
| | border-radius: 4px; |
| | overflow: hidden; |
| | aspect-ratio: 1; |
| | } |
| |
|
| | .image-preview-item img { |
| | width: 100%; |
| | height: 100%; |
| | object-fit: cover; |
| | } |
| |
|
| | .image-preview-count { |
| | text-align: center; |
| | font-size: 0.85em; |
| | color: #666; |
| | margin-top: 8px; |
| | } |
| |
|
| | |
| | @media (max-width: 768px) { |
| | .header-content { |
| | flex-direction: column; |
| | text-align: center; |
| | } |
| |
|
| | .header-right { |
| | text-align: center; |
| | } |
| |
|
| | .logo-container { |
| | flex-wrap: wrap; |
| | justify-content: center; |
| | } |
| |
|
| | .logo-divider { |
| | display: none; |
| | } |
| |
|
| | .input-tabs { |
| | flex-direction: row; |
| | } |
| |
|
| | .input-tab { |
| | border-radius: 6px; |
| | font-size: 0.8em; |
| | padding: 8px 10px; |
| | } |
| |
|
| | .input-tab i { |
| | display: none; |
| | } |
| | } |
| |
|