278 lines
10 KiB
CSS
278 lines
10 KiB
CSS
:root {
|
|
--brand: #1db7ae;
|
|
--brand-600: #12968f;
|
|
--brand-100: #e7f7f6;
|
|
--ink: #24323f;
|
|
--muted: #6b7a88;
|
|
--line: #e6eaef;
|
|
--bg: #ffffff;
|
|
--danger: #e55353;
|
|
--warning: #f59e0b;
|
|
--success: #22c55e;
|
|
--shadow: 0 10px 20px rgba(15, 23, 42, .06);
|
|
--radius: 14px;
|
|
}
|
|
*, *::before, *::after { box-sizing: border-box; }
|
|
body { margin: 0; font-family: Inter, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, "Apple Color Emoji", "Segoe UI Emoji"; color: var(--ink); background: #f6f8fb; }
|
|
a { color: inherit; text-decoration: none; }
|
|
button { font: inherit; }
|
|
|
|
.topbar { background: var(--brand); color: #fff; font-size: .9rem; }
|
|
.topbar .wrap { max-width: 1200px; margin: 0 auto; padding: .5rem 1rem; display: flex; gap: 1rem; align-items: center; justify-content: space-between; }
|
|
.topbar small { opacity: .95; }
|
|
|
|
header { box-shadow: var(--shadow); position: sticky; top: 0; z-index: 30; width: 100%; background: #fff; box-shadow: var(--shadow); position: sticky; top: 0; z-index: 30; display: flex; align-items: center;justify-content: space-between; }
|
|
.logo-link img {
|
|
height: 100px; /* Defina a altura da sua logo aqui */
|
|
width: auto; /* Mantém a proporção da imagem */
|
|
display: block; /* Remove espaços extras abaixo da imagem */
|
|
}
|
|
.wrap { max-width: 1200px; margin: 0 auto; padding: .9rem 1rem; display: flex; align-items: center; justify-content: space-between; }
|
|
.brand {display: flex; margin-left: 200px; align-items: center; gap: .6rem; font-weight: 800; letter-spacing: .4px; }
|
|
.logo { width: 36px; height: 36px; border-radius: 50%; background: linear-gradient(135deg, var(--brand), #4dd7cf); display: grid; place-items: center; color: #fff; font-weight: 700; box-shadow: 0 6px 14px rgba(29,183,174,.35); }
|
|
nav { display: flex; gap: 1.2rem; color: var(--muted); font-weight: 600; }
|
|
.cta { background: var(--brand); color: #fff; padding: .6rem 1rem; border-radius: 999px; box-shadow: 0 10px 18px rgba(29,183,174,.25); transition: .2s ease; }
|
|
.cta:hover { background: var(--brand-600); transform: translateY(-1px); }
|
|
|
|
.container { max-width: 1200px; margin: 28px auto; padding: 0 1rem 4rem; }
|
|
|
|
.card { background: var(--bg); border: 1px solid var(--line); border-radius: var(--radius); box-shadow: var(--shadow); }
|
|
.card .head { padding: 1rem 1.2rem; border-bottom: 1px solid var(--line); display: flex; gap: 1rem; align-items: center; justify-content: space-between; }
|
|
.title { display: flex; gap: .8rem; align-items: center; }
|
|
.title h1 { margin: 0; font-size: 1.25rem; }
|
|
.badge { background: var(--brand-100); color: var(--brand-600); font-weight: 700; padding: .2rem .5rem; border-radius: 6px; font-size: .75rem; }
|
|
|
|
.toolbar { display: grid; grid-template-columns: 1fr auto; gap: .8rem; width: 100%; }
|
|
.search { display: flex; align-items: center; gap: .6rem; background: #f9fbfd; border: 1px solid var(--line); padding: .55rem .8rem; border-radius: 999px; }
|
|
.search input { all: unset; width: 100%; color: var(--ink); }
|
|
.btn { display: inline-flex; gap: .5rem; align-items: center; border: 1px solid transparent; border-radius: 999px; padding: .65rem 1rem; font-weight: 700; cursor: pointer; transition: .2s ease; }
|
|
.btn.primary { background: var(--brand); color: #fff; box-shadow: 0 10px 18px rgba(29,183,174,.25); }
|
|
.btn.primary:hover { background: var(--brand-600); transform: translateY(-1px); }
|
|
|
|
.table { width: 100%; border-collapse: collapse; }
|
|
.table thead th { text-align: left; font-size: .8rem; letter-spacing: .04em; text-transform: uppercase; color: var(--muted); background: #fbfdff; border-bottom: 1px solid var(--line); padding: .9rem .9rem; }
|
|
.table tbody td { padding: .9rem .9rem; border-bottom: 1px solid var(--line); vertical-align: middle; }
|
|
.table tbody tr:hover { background: #fcfefe; }
|
|
|
|
.actions { display: inline-flex; gap: .35rem; }
|
|
.icon-btn { --bg: #f2f6fb; --bd: var(--line); display: inline-grid; place-items: center; width: 34px; height: 34px; border-radius: 10px; border: 1px solid var(--bd); background: var(--bg); transition: .2s ease; }
|
|
.icon-btn:hover { transform: translateY(-1px); box-shadow: var(--shadow); }
|
|
|
|
.table-footer { display: flex; align-items: center; justify-content: space-between; padding: 1rem 1.2rem; }
|
|
.pagination { display: inline-flex; gap: .4rem; }
|
|
.page-btn, .page { min-width: 36px; height: 36px; border-radius: 10px; border: 1px solid var(--line); display: grid; place-items: center; padding: 0 .6rem; background:#fff; cursor:pointer }
|
|
.page-btn.active, .page.is-active { background: var(--brand); color: #fff; border-color: transparent; box-shadow: 0 10px 18px rgba(29,183,174,.25); }
|
|
.col-actions{ text-align:right }
|
|
|
|
@media (max-width: 900px) {
|
|
.toolbar { grid-template-columns: 1fr; }
|
|
.table thead { display: none; }
|
|
.table, .table tbody, .table tr, .table td { display: block; width: 100%; }
|
|
.table tbody tr { border-bottom: 1px solid var(--line); padding: .6rem 0; }
|
|
.table tbody td { border-bottom: none; display: grid; grid-template-columns: 30% 1fr; gap: .6rem; padding: .5rem .9rem; }
|
|
.actions { justify-content: flex-end; }
|
|
}
|
|
:root{
|
|
--brand: #1db7ae;
|
|
--brand-600:#12968f;
|
|
--brand-100:#e7f7f6;
|
|
--ink:#24323f;
|
|
--muted:#6b7a88;
|
|
--line:#e6eaef;
|
|
--bg:#ffffff;
|
|
--shadow: 0 20px 60px rgba(18,150,143,.22);
|
|
}
|
|
|
|
.overlay{
|
|
position: fixed; inset: 0;
|
|
background: rgba(14, 23, 29, .56);
|
|
display: none; align-items: center; justify-content: center;
|
|
padding: 24px;
|
|
z-index: 999;
|
|
}
|
|
.overlay[aria-hidden="false"]{ display:flex; }
|
|
|
|
.carteirinha-wrap{
|
|
width: min(820px, 96vw);
|
|
perspective: 1400px;
|
|
position: relative;
|
|
animation: overlayIn .18s ease-out;
|
|
}
|
|
|
|
@keyframes overlayIn {
|
|
from{ transform: translateY(8px); opacity:.0}
|
|
to{ transform: translateY(0); opacity:1}
|
|
}
|
|
|
|
.close-btn{
|
|
position: absolute;
|
|
top: -14px;
|
|
right: -14px;
|
|
width: 40px; height: 40px;
|
|
border: none; border-radius: 12px;
|
|
background: #fff;
|
|
box-shadow: 0 8px 20px rgba(0,0,0,.18);
|
|
font-size: 28px; line-height: 40px;
|
|
color: #6b7a88; cursor: pointer;
|
|
z-index: 1010; }
|
|
|
|
.close-btn:hover{ transform: translateY(-1px); }
|
|
|
|
.carteirinha{
|
|
background: var(--bg);
|
|
border-radius: 20px;
|
|
box-shadow: var(--shadow);
|
|
overflow: hidden;
|
|
transform: rotateX(14deg) rotateY(-8deg) scale(.96);
|
|
transform-origin: 50% 60%;
|
|
animation: cardEnter .35s cubic-bezier(.22,.9,.27,1.05) forwards;
|
|
}
|
|
|
|
@keyframes cardEnter{
|
|
to { transform: rotateX(0) rotateY(0) scale(1); }
|
|
}
|
|
|
|
.cart-header{
|
|
display:flex; align-items:center; gap:12px;
|
|
background: linear-gradient(135deg, var(--brand), #15a6a0);
|
|
color:#fff; padding: 20px 22px;
|
|
}
|
|
.logo-dot{ width:12px; height:12px; border-radius:50%; background:#fff; opacity:.9 }
|
|
.cart-header h3{ margin:0; font-weight:700; letter-spacing:.3px }
|
|
.tag{
|
|
margin-left:auto; background: rgba(255,255,255,.18);
|
|
border:1px solid rgba(255,255,255,.35);
|
|
padding:6px 10px; border-radius:999px; font-size:12px
|
|
}
|
|
|
|
.cart-body{ padding: 20px 22px; display:grid; grid-template-columns: 120px 1fr; gap: 18px; }
|
|
.avatar{
|
|
position: relative; width:110px; height:110px; border-radius:16px;
|
|
background: var(--brand-100);
|
|
display:grid; place-items:center; font-weight:700; color:var(--brand-600);
|
|
isolation:isolate;
|
|
}
|
|
.avatar-ring{
|
|
position:absolute; inset:-6px;
|
|
border-radius:20px; border: 2px dashed var(--brand-600);
|
|
opacity:.25; animation: spin 10s linear infinite;
|
|
z-index: -1;
|
|
}
|
|
@keyframes spin { to{ transform: rotate(360deg); } }
|
|
.avatar-iniciais{ font-size:28px }
|
|
|
|
.grid{
|
|
display:grid;
|
|
grid-template-columns: repeat(3, minmax(0, 1fr));
|
|
gap: 14px;
|
|
}
|
|
.field label{
|
|
display:block; font-size:12px; color: var(--muted); margin-bottom:4px
|
|
}
|
|
.field p{
|
|
background:#fff; border:1px solid var(--line);
|
|
border-radius:12px; padding:10px 12px; margin:0; color:var(--ink);
|
|
}
|
|
|
|
.obs{ grid-column: 1/-1; }
|
|
.obs label{ display:block; font-size:12px; color:var(--muted); margin:10px 0 6px; }
|
|
.obs p{
|
|
margin:0; background:#fff; border:1px dashed var(--line);
|
|
border-radius:12px; padding:12px; min-height:56px; color:var(--ink)
|
|
}
|
|
|
|
.cart-footer{
|
|
display:flex; align-items:center; gap:16px; justify-content:space-between;
|
|
padding: 12px 18px 18px;
|
|
border-top:1px solid var(--line);
|
|
background: #fafdfd;
|
|
}
|
|
.chips{ display:flex; gap:10px; flex-wrap:wrap }
|
|
.chip{
|
|
background: var(--brand-100); color: var(--brand-600);
|
|
border:1px solid #cbeeed; padding:6px 10px; border-radius:999px; font-size:12px;
|
|
}
|
|
.chip.outline{
|
|
background: #fff; border:1px dashed #cbeeed; color: var(--brand-600);
|
|
}
|
|
.actions{ display:flex; gap:10px }
|
|
button.primary, button.ghost{
|
|
border-radius:12px; padding:10px 14px; border:1px solid var(--line);
|
|
cursor:pointer; font-weight:600;
|
|
}
|
|
button.primary{ background: var(--brand); color:#fff; border-color: transparent; }
|
|
button.primary:hover{ background: var(--brand-600); }
|
|
button.ghost{ background:#fff; color: var(--ink); }
|
|
button.ghost:hover{ border-color: var(--brand-600); color: var(--brand-600); }
|
|
|
|
/* Responsivo */
|
|
@media (max-width: 720px){
|
|
.cart-body{ grid-template-columns: 1fr; }
|
|
.grid{ grid-template-columns: 1fr 1fr; }
|
|
}
|
|
@media (max-width: 440px){
|
|
.grid{ grid-template-columns: 1fr; }
|
|
}
|
|
.navbar {
|
|
gap: 10px;
|
|
|
|
border-bottom:1px solid #e6eaef;
|
|
padding:12px 24px;
|
|
display:flex;
|
|
align-items:center;
|
|
gap:24px;
|
|
font-size:15px;
|
|
}
|
|
.navbar a{
|
|
color:var(--muted);
|
|
text-decoration:none;
|
|
font-weight:500;
|
|
}
|
|
.navbar a:hover{
|
|
color:var(--brand-600);
|
|
}
|
|
.navbar .active{
|
|
background:var(--brand);
|
|
color:#fff;
|
|
padding:8px 18px;
|
|
border-radius:999px;
|
|
font-weight:600;
|
|
box-shadow:0 3px 8px rgba(18,150,143,.25);
|
|
}
|
|
.nav-links {
|
|
display: flex;
|
|
gap: 20px;
|
|
align-items: center;
|
|
}
|
|
|
|
.nav-links a {
|
|
text-decoration: none;
|
|
color: #555;
|
|
font-weight: 500;
|
|
padding: 10px 18px;
|
|
border-radius: 20px;
|
|
transition: background 0.3s ease;
|
|
}
|
|
|
|
.nav-links a.active {
|
|
background: #26bdbd;
|
|
color: white;
|
|
box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
|
|
font-weight: bold;
|
|
}
|
|
|
|
.btn-navbar {
|
|
background: none;
|
|
color: #555;
|
|
border: none;
|
|
padding: 10px 18px;
|
|
border-radius: 20px;
|
|
font-weight: 500;
|
|
cursor: pointer;
|
|
transition: background 0.3s ease;
|
|
}
|
|
|
|
.btn-navbar:hover {
|
|
background: #f0f0f0;
|
|
}
|