Files
BUT2/DragonBank/frontend/static/style.css
T
2026-03-27 10:20:35 +01:00

565 lines
12 KiB
CSS

/* ============================================
DragonBank - Styles CSS
============================================ */
:root {
--dragon-primary: #1a1a2e;
--dragon-secondary: #16213e;
--dragon-accent: #e94560;
--dragon-gold: #f5a623;
--dragon-success: #00b894;
--dragon-info: #0984e3;
--dragon-warning: #fdcb6e;
--dragon-danger: #d63031;
--dragon-light: #f8f9fa;
--dragon-dark: #0f0f23;
--dragon-gradient: linear-gradient(135deg, #1a1a2e 0%, #16213e 50%, #0f3460 100%);
--dragon-card-bg: #ffffff;
--dragon-text: #2d3436;
--dragon-text-light: #636e72;
--dragon-border: #dfe6e9;
--dragon-shadow: 0 4px 15px rgba(0, 0, 0, 0.1);
--dragon-shadow-hover: 0 8px 25px rgba(0, 0, 0, 0.15);
--transition: all 0.3s ease;
}
* {
margin: 0;
padding: 0;
box-sizing: border-box;
}
body {
font-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
background-color: #f0f2f5;
color: var(--dragon-text);
min-height: 100vh;
}
/* ============================================
NAVBAR
============================================ */
.navbar {
background: var(--dragon-gradient) !important;
padding: 0.8rem 1.5rem;
box-shadow: 0 2px 20px rgba(0, 0, 0, 0.3);
}
.navbar-brand {
font-size: 1.5rem;
font-weight: 800;
letter-spacing: 1px;
}
.navbar-brand .dragon-icon {
font-size: 1.8rem;
margin-right: 8px;
}
.nav-link {
color: rgba(255, 255, 255, 0.85) !important;
font-weight: 500;
padding: 0.5rem 1rem !important;
border-radius: 8px;
transition: var(--transition);
margin: 0 2px;
}
.nav-link:hover, .nav-link.active {
color: #fff !important;
background: rgba(255, 255, 255, 0.15);
}
.nav-link i {
margin-right: 5px;
}
.user-badge {
background: rgba(245, 166, 35, 0.2);
border: 1px solid var(--dragon-gold);
color: var(--dragon-gold);
padding: 5px 15px;
border-radius: 20px;
font-weight: 600;
font-size: 0.85rem;
}
/* ============================================
LOGIN PAGE
============================================ */
.login-page {
min-height: 100vh;
background: var(--dragon-gradient);
display: flex;
align-items: center;
justify-content: center;
padding: 20px;
}
.login-container {
width: 100%;
max-width: 450px;
}
.login-header {
text-align: center;
margin-bottom: 2rem;
}
.login-header h1 {
color: #fff;
font-size: 2.5rem;
font-weight: 800;
margin-bottom: 0.5rem;
}
.login-header .dragon-logo {
font-size: 4rem;
display: block;
margin-bottom: 1rem;
}
.login-header p {
color: rgba(255, 255, 255, 0.7);
font-size: 1.1rem;
}
.login-card {
background: white;
border-radius: 20px;
padding: 2.5rem;
box-shadow: 0 20px 60px rgba(0, 0, 0, 0.3);
}
.login-card h2 {
color: var(--dragon-primary);
margin-bottom: 1.5rem;
text-align: center;
font-weight: 700;
}
/* ============================================
FORMS
============================================ */
.form-group {
margin-bottom: 1.2rem;
}
.form-label {
font-weight: 600;
color: var(--dragon-text);
margin-bottom: 0.4rem;
font-size: 0.9rem;
}
.form-control {
border: 2px solid var(--dragon-border);
border-radius: 10px;
padding: 12px 15px;
font-size: 1rem;
transition: var(--transition);
}
.form-control:focus {
border-color: var(--dragon-accent);
box-shadow: 0 0 0 3px rgba(233, 69, 96, 0.15);
}
.form-select {
border: 2px solid var(--dragon-border);
border-radius: 10px;
padding: 12px 15px;
font-size: 1rem;
}
.form-select:focus {
border-color: var(--dragon-accent);
box-shadow: 0 0 0 3px rgba(233, 69, 96, 0.15);
}
/* ============================================
BUTTONS
============================================ */
.btn-dragon {
background: var(--dragon-accent);
color: white;
border: none;
padding: 12px 30px;
border-radius: 10px;
font-weight: 700;
font-size: 1rem;
transition: var(--transition);
text-transform: uppercase;
letter-spacing: 1px;
}
.btn-dragon:hover {
background: #d63051;
color: white;
transform: translateY(-2px);
box-shadow: 0 5px 20px rgba(233, 69, 96, 0.4);
}
.btn-dragon-outline {
background: transparent;
color: var(--dragon-accent);
border: 2px solid var(--dragon-accent);
padding: 10px 25px;
border-radius: 10px;
font-weight: 600;
transition: var(--transition);
}
.btn-dragon-outline:hover {
background: var(--dragon-accent);
color: white;
}
.btn-gold {
background: var(--dragon-gold);
color: var(--dragon-dark);
border: none;
padding: 12px 30px;
border-radius: 10px;
font-weight: 700;
transition: var(--transition);
}
.btn-gold:hover {
background: #e09500;
transform: translateY(-2px);
box-shadow: 0 5px 20px rgba(245, 166, 35, 0.4);
}
.btn-success-custom {
background: var(--dragon-success);
color: white;
border: none;
padding: 12px 30px;
border-radius: 10px;
font-weight: 700;
transition: var(--transition);
}
.btn-success-custom:hover {
background: #00a383;
color: white;
transform: translateY(-2px);
}
/* ============================================
DASHBOARD
============================================ */
.main-content {
padding: 2rem;
max-width: 1400px;
margin: 0 auto;
}
.page-header {
margin-bottom: 2rem;
}
.page-header h1 {
color: var(--dragon-primary);
font-weight: 800;
font-size: 2rem;
}
.page-header p {
color: var(--dragon-text-light);
font-size: 1.1rem;
}
/* ============================================
STAT CARDS
============================================ */
.stat-card {
background: white;
border-radius: 16px;
padding: 1.5rem;
box-shadow: var(--dragon-shadow);
transition: var(--transition);
border: none;
position: relative;
overflow: hidden;
}
.stat-card::before {
content: '';
position: absolute;
top: 0;
left: 0;
right: 0;
height: 4px;
}
.stat-card:hover {
transform: translateY(-5px);
box-shadow: var(--dragon-shadow-hover);
}
.stat-card.primary::before { background: var(--dragon-accent); }
.stat-card.success::before { background: var(--dragon-success); }
.stat-card.info::before { background: var(--dragon-info); }
.stat-card.warning::before { background: var(--dragon-gold); }
.stat-card .stat-icon {
width: 60px;
height: 60px;
border-radius: 15px;
display: flex;
align-items: center;
justify-content: center;
font-size: 1.5rem;
margin-bottom: 1rem;
}
.stat-card.primary .stat-icon { background: rgba(233, 69, 96, 0.1); color: var(--dragon-accent); }
.stat-card.success .stat-icon { background: rgba(0, 184, 148, 0.1); color: var(--dragon-success); }
.stat-card.info .stat-icon { background: rgba(9, 132, 227, 0.1); color: var(--dragon-info); }
.stat-card.warning .stat-icon { background: rgba(245, 166, 35, 0.1); color: var(--dragon-gold); }
.stat-card .stat-value {
font-size: 1.8rem;
font-weight: 800;
color: var(--dragon-primary);
line-height: 1;
}
.stat-card .stat-label {
font-size: 0.85rem;
color: var(--dragon-text-light);
margin-top: 0.3rem;
font-weight: 500;
}
/* ============================================
ACCOUNT CARDS
============================================ */
.account-card {
background: white;
border-radius: 16px;
padding: 1.5rem;
box-shadow: var(--dragon-shadow);
transition: var(--transition);
margin-bottom: 1rem;
border-left: 5px solid;
}
.account-card:hover {
transform: translateY(-3px);
box-shadow: var(--dragon-shadow-hover);
}
.account-card.courant { border-left-color: var(--dragon-info); }
.account-card.livret_a { border-left-color: var(--dragon-success); }
.account-card.assurance_vie { border-left-color: var(--dragon-gold); }
.account-type-badge {
display: inline-block;
padding: 4px 12px;
border-radius: 20px;
font-size: 0.75rem;
font-weight: 700;
text-transform: uppercase;
letter-spacing: 1px;
}
.account-type-badge.courant { background: rgba(9, 132, 227, 0.1); color: var(--dragon-info); }
.account-type-badge.livret_a { background: rgba(0, 184, 148, 0.1); color: var(--dragon-success); }
.account-type-badge.assurance_vie { background: rgba(245, 166, 35, 0.1); color: var(--dragon-gold); }
.account-balance {
font-size: 2rem;
font-weight: 800;
color: var(--dragon-primary);
}
.account-number {
font-family: 'Courier New', monospace;
color: var(--dragon-text-light);
font-size: 0.9rem;
letter-spacing: 2px;
}
/* ============================================
TABLES
============================================ */
.custom-table {
background: white;
border-radius: 16px;
overflow: hidden;
box-shadow: var(--dragon-shadow);
}
.custom-table .table {
margin-bottom: 0;
}
.custom-table .table thead {
background: var(--dragon-primary);
color: white;
}
.custom-table .table thead th {
font-weight: 600;
padding: 1rem;
border: none;
font-size: 0.85rem;
text-transform: uppercase;
letter-spacing: 0.5px;
}
.custom-table .table tbody td {
padding: 1rem;
vertical-align: middle;
border-bottom: 1px solid var(--dragon-border);
}
.custom-table .table tbody tr:hover {
background-color: rgba(233, 69, 96, 0.03);
}
.transaction-amount.credit {
color: var(--dragon-success);
font-weight: 700;
}
.transaction-amount.debit {
color: var(--dragon-danger);
font-weight: 700;
}
/* ============================================
TRANSACTION STATUS BADGES
============================================ */
.status-badge {
padding: 4px 12px;
border-radius: 20px;
font-size: 0.75rem;
font-weight: 700;
}
.status-badge.completed { background: rgba(0, 184, 148, 0.1); color: var(--dragon-success); }
.status-badge.pending { background: rgba(253, 203, 110, 0.2); color: #e17055; }
.status-badge.failed { background: rgba(214, 48, 49, 0.1); color: var(--dragon-danger); }
/* ============================================
SECTIONS
============================================ */
.section-card {
background: white;
border-radius: 16px;
padding: 1.5rem;
box-shadow: var(--dragon-shadow);
margin-bottom: 1.5rem;
}
.section-card .section-title {
font-size: 1.2rem;
font-weight: 700;
color: var(--dragon-primary);
margin-bottom: 1rem;
padding-bottom: 0.5rem;
border-bottom: 2px solid var(--dragon-border);
}
/* ============================================
ALERTS
============================================ */
.alert {
border: none;
border-radius: 12px;
padding: 1rem 1.5rem;
font-weight: 500;
}
.alert-success {
background: rgba(0, 184, 148, 0.1);
color: #00a383;
border-left: 4px solid var(--dragon-success);
}
.alert-danger {
background: rgba(214, 48, 49, 0.1);
color: #c0392b;
border-left: 4px solid var(--dragon-danger);
}
.alert-warning {
background: rgba(253, 203, 110, 0.15);
color: #e17055;
border-left: 4px solid var(--dragon-gold);
}
.alert-info {
background: rgba(9, 132, 227, 0.1);
color: var(--dragon-info);
border-left: 4px solid var(--dragon-info);
}
/* ============================================
RESPONSIVE
============================================ */
@media (max-width: 768px) {
.main-content {
padding: 1rem;
}
.stat-card .stat-value {
font-size: 1.4rem;
}
.account-balance {
font-size: 1.5rem;
}
.login-card {
padding: 1.5rem;
}
.login-header h1 {
font-size: 2rem;
}
}
/* ============================================
ANIMATIONS
============================================ */
@keyframes fadeInUp {
from {
opacity: 0;
transform: translateY(20px);
}
to {
opacity: 1;
transform: translateY(0);
}
}
.fade-in {
animation: fadeInUp 0.5s ease forwards;
}
.delay-1 { animation-delay: 0.1s; }
.delay-2 { animation-delay: 0.2s; }
.delay-3 { animation-delay: 0.3s; }
.delay-4 { animation-delay: 0.4s; }
/* ============================================
FOOTER
============================================ */
.footer {
background: var(--dragon-primary);
color: rgba(255, 255, 255, 0.6);
text-align: center;
padding: 1.5rem;
margin-top: 3rem;
font-size: 0.85rem;
}
.footer a {
color: var(--dragon-gold);
text-decoration: none;
}