 :root{
       --bg:#0D1B2A;       /* dark navy background */
       --ink:#E0E1DD;      /* light gray text */
       --muted:#778DA9;    /* steel blue muted text */
       --accent:#415A77;   /* slate blue accents */
       --card:#343A40;     /* lighter dark gray tiles */
       --border:#415A77;   /* slate blue borders */
       --radius:14px;
       --shadow:0 8px 24px rgba(0,0,0,.45);
       --ring:0 0 0 3px rgba(65,90,119,.5);
   }

*{box-sizing:border-box}
body{
    margin:0;
    font:16px/1.6 system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
    color:var(--ink);
    background:var(--bg);
    overflow-x:hidden;
}

#bgCanvas{
    position:fixed;
    top:0; left:0;
    width:100%; height:100%;
    z-index:-1;
    background:var(--bg);
}

.wrap{max-width:1100px; margin:auto; padding:32px 20px 80px; position:relative;}

/* ===== Header / Menu ===== */
.name-box{
    position:relative; display:flex; align-items:center; justify-content:center;
    min-height:88px; padding:16px 56px;
    background:var(--card); border:1px solid var(--border);
    border-radius:var(--radius); box-shadow:var(--shadow); color:var(--ink);
}
.brand{font-size:40px; font-weight:800; letter-spacing:.5px; color:var(--ink);}

.menu-dd{position:absolute; top:10px; right:10px;}
.menu-dd > summary{
    list-style:none; cursor:pointer; user-select:none;
    padding:8px 14px; border:1px solid var(--border);
    background:var(--accent); color:#fff; border-radius:10px; font-weight:700;
}
.menu-dd > summary::-webkit-details-marker{display:none}
.menu-dd[open] > summary{background:#778DA9;}
.menu-panel{
    position:absolute; right:0; margin-top:8px; width:300px;
    background:var(--card); border:1px solid var(--border);
    border-radius:12px; box-shadow:var(--shadow); padding:14px; z-index:20;
}

.group-title{margin:4px 0 10px; font-weight:800; font-size:13px; color:var(--muted); text-transform:uppercase; letter-spacing:.06em}
.menu-links{display:flex; flex-direction:column; gap:10px; margin-bottom:14px;}
.link-btn{
    display:flex; align-items:center; justify-content:center;
    padding:10px 12px; border:1px solid var(--border); border-radius:10px;
    background:#0D1B2A; font-weight:700; color:var(--ink);
}
.link-btn:hover{border-color:var(--accent); background:#415A77;}
.divider{height:1px; background:var(--border); margin:10px 0;}

.login-panel h4{margin:0 0 8px; font-size:16px; font-weight:800}
.login-panel label{display:block; font-size:13px; color:var(--muted); margin:10px 0 4px}
.login-panel input{width:100%; padding:10px 12px; border:1px solid var(--border); border-radius:10px; outline:none; background:#0D1B2A; color:var(--ink);}
.login-panel input:focus{border-color:var(--accent); box-shadow:var(--ring)}
.login-actions{display:flex; gap:10px; margin-top:12px}
.btn{flex:1; padding:10px 14px; border-radius:10px; font-weight:700; text-align:center; border:1px solid transparent; cursor:pointer}
.btn-primary{background:var(--accent); color:#fff}
.btn-secondary{background:#0D1B2A; border:1px solid var(--border); color:var(--ink)}

/* ===== Projects Layout ===== */
.projects{display:flex; flex-direction:column; gap:40px; margin-top:26px;}
.project{display:flex;
    align-items:stretch;
    gap:18px;
    border: 1px solid var(--border);
    border-radius: var(--radius);
    background: var(--card);
    box-shadow: var(--shadow);
    padding: 10px;}
 .shot {
     flex: 0 0 300px;
     height: 200px; /* set fixed height */
     border: 1px solid var(--border);
     border-radius: var(--radius);
     background: #0D1B2A;
     box-shadow: var(--shadow);
     overflow: hidden;
     display: flex;
 }

 .shot img {
     width: 100%;
     height: 100%;
     object-fit: cover; /* crops but keeps ratio */
     display: block;
 }

.shot .ph{margin:auto; color:var(--muted); font-weight:700; text-align:center}

.info{
    flex:1; display:flex; flex-direction:column; gap:8px;
}
.title{font-size:26px; font-weight:800; margin:0; color:var(--ink);}
.dates{color:var(--muted); font-size:.95rem}
.project details{margin-top:auto; border-top:1px dashed var(--border); padding-top:10px}
.project details > summary{list-style:none; cursor:pointer; font-weight:700; display:flex; align-items:center; color:var(--ink);}
.project details > summary::after{content:" → open info"; color:var(--accent); font-weight:800; margin-left:auto}
.project details[open] > summary::after{content:" ← close info"}

/* ===== About layout ===== */
.about{
    margin-top:26px;
    display:flex;
    gap:28px;
    align-items:stretch;
}
.leftCol{
    display:flex; flex-direction:column; gap:22px; flex:0 0 340px;
}
.avatar{
    width:320px; height:320px; max-width:100%;
    border-radius:50%; overflow:hidden;
    border:1px solid var(--border); background:var(--card); box-shadow:var(--shadow);
    display:flex;
}
.avatar img{width:100%; height:100%; object-fit:cover; display:block;}

.links{
    background:var(--card); border:1px solid var(--border);
    border-radius:var(--radius); box-shadow:var(--shadow);
    padding:16px; min-height:180px;
}
.links h3{margin:0 0 10px;}
.links ul{list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:10px}
.links a{display:block; padding:10px 12px; border:1px dashed var(--border); border-radius:10px; background:#0D1B2A; color:var(--ink); font-weight:700}
.links a:hover{border-color:var(--accent); background:#415A77;}

.bio{
    flex:1;
    display:flex; flex-direction:column; justify-content:flex-start;
    background:var(--card); border:1px solid var(--border);
    border-radius:var(--radius); box-shadow:var(--shadow);
    padding:22px 24px;
}
.bio h2{margin:0 0 8px; color:var(--ink);}
.bio p{margin:10px 0; color:var(--ink);}

#contact{margin-top:40px; padding:22px; background:var(--card); border:1px solid var(--border); border-radius:var(--radius); box-shadow:var(--shadow);}
#contact h2{margin:0 0 8px}

/* ===== Experience layout ===== */
.exp-page{
    margin-top:26px;
    display:flex;
    gap:24px;
    align-items:flex-start;
}
.xp-list{
    flex:1;
    display:flex;
    flex-direction:column;
    gap:22px;
}
.xp-card{
    position:relative;
    overflow:hidden;
    background:var(--card);
    border:1px solid var(--border);
    border-radius:var(--radius);
    box-shadow:var(--shadow);
    padding:20px 22px;
    min-height:180px;
}
.xp-body{
    position:relative;
    z-index:2;
    max-width:78%;
}
.xp-title{ font-size:26px; font-weight:800; margin:0 0 8px; color:var(--ink);}
.xp-desc{ margin:6px 0 10px; color:var(--ink);}
.xp-dates{ color:var(--muted); font-weight:700; }
.xp-art{
    position:absolute;
    top:0; right:0; bottom:0;
    width:22%;
    background-size:cover;
    background-position:center;
    pointer-events:none;
    clip-path: polygon(60% 0, 100% 0, 100% 100%, 45% 100%);
    -webkit-mask-image: linear-gradient(to left, rgba(0,0,0,1) 55%, rgba(0,0,0,0) 100%);
    mask-image: linear-gradient(to left, rgba(0,0,0,1) 55%, rgba(0,0,0,0) 100%);
}
.xp-art::after{
    content:"";
    position:absolute; inset:0;
    background:linear-gradient(to left, rgba(52,58,64,0) 0%, rgba(52,58,64,1) 90%);
}

/* Responsive */
@media (max-width: 980px){
    .exp-page{ flex-direction:column; }
    .skills{ position:static; }
    .xp-body{ max-width:100%; }
    .xp-art{ width:48%; clip-path: polygon(50% 0, 100% 0, 100% 100%, 35% 100%); }
}
@media (max-width: 560px){
    .xp-card{ padding:16px; }
    .xp-title{ font-size:22px; }
    .xp-art{ width:60%; }
}
 .btn.action-btn {
     display: inline-block;
     padding: 6px 14px;
     font-size: 14px;
     font-weight: 500;
     border: 1px solid #ccc;
     border-radius: 6px;
     background: #f0f0f0;
     color: #1b1f24;
     cursor: pointer;
     text-decoration: none;
     transition: background 0.2s, transform 0.1s;
 }

 .btn.action-btn:hover {
     background: #e0e0e0;
     transform: translateY(-2px);
 }

 .btn.action-btn:active {
     transform: translateY(0);
 }

 .btn.action-btn.delete-btn {
     background: #f87171; /* red-ish */
     color: white;
     border-color: #f87171;
 }

 .btn.action-btn.delete-btn:hover {
     background: #dc2626;
 }

 /* ===== Admin Panel Styling ===== */
 .panel {
     background: var(--card);
     border: 1px solid var(--border);
     border-radius: var(--radius);
     box-shadow: var(--shadow);
     padding: 22px 24px;
     display: flex;
     flex-direction: column;
     gap: 16px;
 }

 .panel h3 {
     margin: 0 0 12px;
     font-size: 20px;
     font-weight: 700;
     color: var(--ink);
     border-bottom: 1px solid var(--border);
     padding-bottom: 6px;
 }

 .form-grid {
     display: grid;
     grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
     gap: 16px 20px;
 }

 .form-grid label {
     display: block;
     font-size: 13px;
     font-weight: 600;
     margin-bottom: 6px;
     color: var(--muted);
 }

 .form-grid input,
 .form-grid textarea {
     width: 100%;
     padding: 10px 12px;
     border: 1px solid var(--border);
     border-radius: var(--radius);
     background: var(--bg);
     color: var(--ink);
     font-size: 14px;
 }

 .form-grid input:focus,
 .form-grid textarea:focus {
     outline: none;
     border-color: var(--accent);
     box-shadow: var(--ring);
 }

 .form-grid textarea {
     resize: vertical;
     min-height: 100px;
 }

 .actions {
     display: flex;
     gap: 10px;
     margin-top: 12px;
 }

 .btn {
     display: inline-flex;
     align-items: center;
     justify-content: center;
     font-weight: 600;
     padding: 10px 14px;
     border-radius: var(--radius);
     border: 1px solid transparent;
     background: var(--accent);
     color: #fff;
     cursor: pointer;
     text-decoration: none;
     transition: background 0.2s, transform 0.1s, border-color 0.2s;
 }

 .btn:hover {
     background: #778DA9;
     border-color: var(--accent);
 }

 .btn.delete-btn {
     background: #f87171; /* red-ish */
     border-color: #f87171;
     color: #fff;
 }

 .btn.delete-btn:hover {
     background: #dc2626;
 }
 /* ===== Edit Project Form Panel ===== */
 .panel {
     background: var(--card);
     border: 1px solid var(--border);
     border-radius: var(--radius);
     box-shadow: var(--shadow);
     padding: 22px 24px;
     display: flex;
     flex-direction: column;
     gap: 18px;
 }

 .panel h3 {
     margin: 0 0 14px;
     font-size: 22px;
     font-weight: 700;
     color: var(--ink);
     border-bottom: 1px solid var(--border);
     padding-bottom: 6px;
 }

 /* Grid form layout */
 .form-grid {
     display: grid;
     grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
     gap: 16px 20px;
 }

 .form-grid label {
     display: block;
     font-size: 13px;
     font-weight: 600;
     margin-bottom: 6px;
     color: var(--muted);
 }

 .form-grid input,
 .form-grid textarea {
     width: 100%;
     padding: 10px 12px;
     border: 1px solid var(--border);
     border-radius: var(--radius);
     background: var(--bg);
     color: var(--ink);
     font-size: 14px;
 }

 .form-grid input:focus,
 .form-grid textarea:focus {
     outline: none;
     border-color: var(--accent);
     box-shadow: var(--ring);
 }

 .form-grid textarea {
     resize: vertical;
     min-height: 100px;
 }

 /* Row helper inside form */
 .form-grid .row {
     display: flex;
     gap: 16px;
 }

 .form-grid .row > div {
     flex: 1;
 }

 /* Actions row */
 .actions {
     display: flex;
     gap: 10px;
     margin-top: 14px;
 }

 .actions .btn {
     flex: 0 0 auto;
 }
 /* Sidebar */
 .skills{
     flex:0 0 260px;
     background:var(--card);
     border:1px solid var(--border);
     border-radius:var(--radius);
     box-shadow:var(--shadow);
     padding:16px;
     position:sticky; top:20px;
 }
 .skills h3{ margin:0 0 8px; color:var(--ink);}
 .pillbox{ display:flex; flex-wrap:wrap; gap:8px; }
 .pill{
     padding:8px 10px;
     background:#0D1B2A;
     border:1px dashed var(--border);
     border-radius:999px;
     font-weight:700;
     font-size:.95rem;
     color:var(--ink);
 }

 /* Responsive Projects Layout */
 @media (max-width: 768px) {
     .project {
         flex-direction: column;   /* stack vertically */
     }

     .shot {
         flex: 0 0 auto;          /* remove fixed width */
         width: 100%;             /* take full width */
         height: 220px;           /* reasonable height for mobile */
     }

     .info {
         width: 100%;             /* full width below image */
     }
 }

 @media (max-width: 480px) {
     .shot {
         height: 180px;           /* shorter for small phones */
     }

     .title {
         font-size: 20px;
     }
 }
 @media (max-width: 768px) {
     .menu-panel {
         position: fixed;
         top: 60px;         /* just below the header */
         left: 0;
         right: 0;
         width: 100%;       /* full width */
         margin: 0;
         border-radius: 0;  /* flat edges for mobile */
         border-left: none;
         border-right: none;
         box-shadow: var(--shadow);
         z-index: 999;
     }

     .menu-dd {
         position: static;  /* keeps the button aligned in header */
     }

     .menu-dd > summary {
         width: 100%;
         text-align: center;
     }
 }
